@adaptabletools/adaptable-cjs 18.0.0-canary.3 → 18.0.0-canary.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (206) hide show
  1. package/agGrid.d.ts +4 -21
  2. package/agGrid.js +5 -21
  3. package/base.css +4 -1
  4. package/base.css.map +1 -1
  5. package/index.css +79 -68
  6. package/index.css.map +1 -1
  7. package/package.json +3 -4
  8. package/src/AdaptableInterfaces/IAdaptable.d.ts +55 -109
  9. package/src/AdaptableOptions/AdaptableOptions.d.ts +11 -5
  10. package/src/AdaptableOptions/ColumnFilterOptions.d.ts +4 -4
  11. package/src/AdaptableOptions/{CommentsOptions.d.ts → CommentOptions.d.ts} +5 -5
  12. package/src/AdaptableOptions/MenuOptions.d.ts +1 -1
  13. package/src/AdaptableOptions/MenuOptions.js +2 -6
  14. package/src/AdaptableOptions/{NotesOptions.d.ts → NoteOptions.d.ts} +1 -1
  15. package/src/AdaptableOptions/UserInterfaceOptions.d.ts +17 -0
  16. package/src/Api/AdaptableApi.d.ts +5 -0
  17. package/src/Api/BulkUpdateApi.d.ts +0 -5
  18. package/src/Api/Events/AdaptableReady.d.ts +3 -3
  19. package/src/Api/Events/GridDataChanged.d.ts +4 -4
  20. package/src/Api/GridApi.d.ts +14 -13
  21. package/src/Api/Implementation/ActionColumnApiImpl.d.ts +2 -0
  22. package/src/Api/Implementation/ActionColumnApiImpl.js +33 -0
  23. package/src/Api/Implementation/AdaptableApiImpl.d.ts +1 -0
  24. package/src/Api/Implementation/AdaptableApiImpl.js +3 -0
  25. package/src/Api/Implementation/ApiBase.d.ts +2 -1
  26. package/src/Api/Implementation/ApiBase.js +4 -1
  27. package/src/Api/Implementation/BulkUpdateApiImpl.d.ts +0 -1
  28. package/src/Api/Implementation/BulkUpdateApiImpl.js +0 -4
  29. package/src/Api/Implementation/CommentsApiImpl.js +2 -1
  30. package/src/Api/Implementation/ConfigApiImpl.js +8 -3
  31. package/src/Api/Implementation/GridApiImpl.d.ts +3 -3
  32. package/src/Api/Implementation/GridApiImpl.js +20 -14
  33. package/src/Api/Implementation/LayoutApiImpl.d.ts +4 -0
  34. package/src/Api/Implementation/LayoutApiImpl.js +14 -0
  35. package/src/Api/Implementation/NotesApiImpl.d.ts +2 -4
  36. package/src/Api/Implementation/NotesApiImpl.js +4 -8
  37. package/src/Api/Implementation/OptionsApiImpl.d.ts +1 -1
  38. package/src/Api/Implementation/OptionsApiImpl.js +2 -2
  39. package/src/Api/Implementation/StatusBarApiImpl.d.ts +0 -1
  40. package/src/Api/Implementation/StatusBarApiImpl.js +0 -3
  41. package/src/Api/Implementation/ToolPanelApiImpl.js +6 -6
  42. package/src/Api/Internal/ActionRowInternalApi.d.ts +5 -1
  43. package/src/Api/Internal/ActionRowInternalApi.js +107 -0
  44. package/src/Api/Internal/AdaptableInternalApi.d.ts +3 -4
  45. package/src/Api/Internal/AdaptableInternalApi.js +10 -8
  46. package/src/Api/Internal/CalculatedColumnInternalApi.d.ts +2 -0
  47. package/src/Api/Internal/CalculatedColumnInternalApi.js +71 -0
  48. package/src/Api/Internal/ColumnFilterInternalApi.d.ts +1 -0
  49. package/src/Api/Internal/ColumnFilterInternalApi.js +11 -1
  50. package/src/Api/Internal/ColumnInternalApi.d.ts +4 -1
  51. package/src/Api/Internal/ColumnInternalApi.js +12 -0
  52. package/src/Api/Internal/CustomSortInternalApi.d.ts +3 -2
  53. package/src/Api/Internal/CustomSortInternalApi.js +32 -1
  54. package/src/Api/Internal/DataSetInternalApi.js +1 -1
  55. package/src/Api/Internal/FreeTextColumnInternalApi.d.ts +2 -0
  56. package/src/Api/Internal/FreeTextColumnInternalApi.js +60 -0
  57. package/src/Api/Internal/GridFilterInternalApi.js +1 -1
  58. package/src/Api/Internal/GridInternalApi.d.ts +21 -3
  59. package/src/Api/Internal/GridInternalApi.js +126 -7
  60. package/src/Api/Internal/TeamSharingInternalApi.js +1 -1
  61. package/src/Api/InteropioPluginApi.d.ts +2 -2
  62. package/src/Api/LayoutApi.d.ts +8 -0
  63. package/src/Api/OptionsApi.d.ts +1 -1
  64. package/src/EnvVars.d.ts +3 -0
  65. package/src/EnvVars.js +8 -0
  66. package/src/PredefinedConfig/Common/AggregationColumns.d.ts +1 -0
  67. package/src/PredefinedConfig/Common/AggregationColumns.js +5 -1
  68. package/src/PredefinedConfig/NotesState.d.ts +10 -20
  69. package/src/PredefinedConfig/PredefinedConfig.d.ts +1 -1
  70. package/src/Redux/ActionsReducers/NotesRedux.d.ts +3 -4
  71. package/src/Redux/ActionsReducers/NotesRedux.js +10 -8
  72. package/src/Redux/Store/AdaptableStore.d.ts +4 -6
  73. package/src/Redux/Store/AdaptableStore.js +22 -50
  74. package/src/Redux/Store/Interface/IAdaptableStore.d.ts +7 -1
  75. package/src/Strategy/AdaptableModuleBase.d.ts +2 -3
  76. package/src/Strategy/AdaptableModuleBase.js +4 -7
  77. package/src/Strategy/AlertModule.d.ts +1 -2
  78. package/src/Strategy/AlertModule.js +2 -55
  79. package/src/Strategy/CalculatedColumnModule.d.ts +2 -3
  80. package/src/Strategy/CalculatedColumnModule.js +5 -25
  81. package/src/Strategy/ChartingModule.d.ts +0 -1
  82. package/src/Strategy/ChartingModule.js +2 -22
  83. package/src/Strategy/ColumnFilterModule.d.ts +1 -2
  84. package/src/Strategy/ColumnFilterModule.js +1 -64
  85. package/src/Strategy/CommentsModule.d.ts +1 -0
  86. package/src/Strategy/CommentsModule.js +2 -1
  87. package/src/Strategy/CustomSortModule.js +1 -1
  88. package/src/Strategy/DashboardModule.d.ts +1 -2
  89. package/src/Strategy/DashboardModule.js +1 -8
  90. package/src/Strategy/DataChangeHistoryModule.d.ts +1 -0
  91. package/src/Strategy/DataChangeHistoryModule.js +3 -1
  92. package/src/Strategy/DataSetModule.d.ts +1 -1
  93. package/src/Strategy/DataSetModule.js +1 -1
  94. package/src/Strategy/FlashingCellModule.d.ts +1 -2
  95. package/src/Strategy/FlashingCellModule.js +2 -15
  96. package/src/Strategy/FormatColumnModule.d.ts +0 -2
  97. package/src/Strategy/FormatColumnModule.js +0 -47
  98. package/src/Strategy/FreeTextColumnModule.d.ts +0 -1
  99. package/src/Strategy/FreeTextColumnModule.js +0 -30
  100. package/src/Strategy/GridFilterModule.d.ts +0 -1
  101. package/src/Strategy/GridFilterModule.js +0 -37
  102. package/src/Strategy/Interface/IModule.d.ts +0 -1
  103. package/src/Strategy/LayoutModule.d.ts +1 -3
  104. package/src/Strategy/LayoutModule.js +6 -50
  105. package/src/Strategy/NamedQueryModule.d.ts +0 -1
  106. package/src/Strategy/NamedQueryModule.js +0 -19
  107. package/src/Strategy/PlusMinusModule.d.ts +1 -1
  108. package/src/Strategy/PlusMinusModule.js +1 -1
  109. package/src/Strategy/ScheduleModule.d.ts +1 -1
  110. package/src/Strategy/ScheduleModule.js +1 -1
  111. package/src/Strategy/ShortcutModule.d.ts +1 -1
  112. package/src/Strategy/ShortcutModule.js +1 -1
  113. package/src/Strategy/StyledColumnModule.d.ts +0 -1
  114. package/src/Strategy/StyledColumnModule.js +0 -21
  115. package/src/Strategy/TeamSharingModule.d.ts +1 -0
  116. package/src/Strategy/TeamSharingModule.js +5 -5
  117. package/src/Strategy/ToolPanelModule.d.ts +0 -1
  118. package/src/Strategy/ToolPanelModule.js +0 -23
  119. package/src/Utilities/Constants/DocumentationLinkConstants.js +1 -1
  120. package/src/Utilities/Constants/GeneralConstants.d.ts +1 -0
  121. package/src/Utilities/Constants/GeneralConstants.js +3 -2
  122. package/src/Utilities/Defaults/DefaultSettingsPanel.js +5 -4
  123. package/src/Utilities/Helpers/AdaptableHelper.d.ts +0 -3
  124. package/src/Utilities/Helpers/AdaptableHelper.js +1 -60
  125. package/src/Utilities/Helpers/Helper.d.ts +2 -0
  126. package/src/Utilities/Helpers/Helper.js +6 -1
  127. package/src/Utilities/Services/AggregatedScalarLiveValue.js +3 -1
  128. package/src/Utilities/Services/CellPopupService.js +0 -1
  129. package/src/Utilities/Services/LicenseService/index.d.ts +3 -0
  130. package/src/Utilities/Services/LicenseService/index.js +10 -3
  131. package/src/Utilities/Services/MetamodelService.d.ts +1 -1
  132. package/src/Utilities/Services/MetamodelService.js +6 -3
  133. package/src/Utilities/Services/RowEditService.d.ts +3 -2
  134. package/src/Utilities/Services/RowEditService.js +3 -1
  135. package/src/View/AdaptableView.js +0 -2
  136. package/src/View/AdaptableWizardView/AdaptableConfigurationDialog/ConfigurationWizard.js +2 -2
  137. package/src/View/BulkUpdate/BulkUpdatePopup.js +1 -1
  138. package/src/View/CalculatedColumn/utils.d.ts +1 -1
  139. package/src/View/CellSummary/CellSummaryPopup.js +1 -1
  140. package/src/View/Comments/CommentsPopup.js +12 -8
  141. package/src/View/Components/Popups/AdaptableLoadingScreen.d.ts +6 -5
  142. package/src/View/Components/Popups/AdaptableLoadingScreen.js +19 -9
  143. package/src/View/Components/Popups/GridCellPopup/GridCellPopup.js +1 -1
  144. package/src/View/Components/Popups/WindowPopups/windowFactory.d.ts +1 -0
  145. package/src/View/Components/Popups/WindowPopups/windowFactory.js +4 -1
  146. package/src/View/Components/Selectors/PermittedValuesSelector.js +1 -1
  147. package/src/View/CustomSort/CustomSortSummary.js +1 -1
  148. package/src/View/DataChangeHistory/DataChangeHistoryGrid.js +1 -1
  149. package/src/View/GridFilter/GridFilterViewPanel.js +6 -2
  150. package/src/View/GridInfo/GridInfoPopup/GridInfoPopup.js +2 -3
  151. package/src/View/Layout/TransposedPopup.d.ts +3 -0
  152. package/src/View/Layout/TransposedPopup.js +198 -0
  153. package/src/View/Layout/Wizard/LayoutWizard.js +1 -1
  154. package/src/View/Notes/NotesPopup.js +8 -10
  155. package/src/View/Theme/ThemeSelector.js +2 -2
  156. package/src/agGrid/ActionColumnRenderer.js +4 -4
  157. package/src/agGrid/Adaptable.d.ts +3 -455
  158. package/src/agGrid/Adaptable.js +7 -5291
  159. package/src/agGrid/AdaptableAgGrid.d.ts +336 -0
  160. package/src/agGrid/AdaptableAgGrid.js +3785 -0
  161. package/src/agGrid/AdaptableLogger.js +78 -13
  162. package/src/agGrid/AgGridAdapter.d.ts +54 -0
  163. package/src/agGrid/AgGridAdapter.js +554 -0
  164. package/src/agGrid/AgGridColumnAdapter.d.ts +56 -0
  165. package/src/agGrid/AgGridColumnAdapter.js +818 -0
  166. package/src/agGrid/AgGridMenuAdapter.d.ts +28 -0
  167. package/src/agGrid/AgGridMenuAdapter.js +276 -0
  168. package/src/agGrid/AgGridOptionsService.d.ts +11 -0
  169. package/src/agGrid/AgGridOptionsService.js +54 -0
  170. package/src/agGrid/BadgeRenderer.js +1 -1
  171. package/src/agGrid/CheckboxRenderer.js +1 -1
  172. package/src/agGrid/FilterWrapper.d.ts +2 -2
  173. package/src/agGrid/FilterWrapper.js +1 -1
  174. package/src/agGrid/attachAddaptableColumnTypes.d.ts +12 -12
  175. package/src/agGrid/defaultAdaptableOptions.d.ts +3 -0
  176. package/src/{Utilities/Defaults/DefaultAdaptableOptions.js → agGrid/defaultAdaptableOptions.js} +73 -10
  177. package/src/agGrid/editors/AdaptableDateEditor/index.js +2 -2
  178. package/src/agGrid/editors/AdaptableNumberEditor/index.js +2 -2
  179. package/src/components/Datepicker/index.d.ts +1 -1
  180. package/src/components/InfiniteTable/index.js +2 -2
  181. package/src/components/Modal/index.d.ts +1 -0
  182. package/src/components/Modal/index.js +6 -4
  183. package/src/components/Select/Select.d.ts +2 -0
  184. package/src/components/Select/Select.js +2 -2
  185. package/src/env.js +2 -2
  186. package/src/metamodel/adaptable.metamodel.d.ts +39 -11
  187. package/src/metamodel/adaptable.metamodel.js +73 -32
  188. package/src/migration/AdaptableUpgradeHelper.d.ts +38 -0
  189. package/src/migration/AdaptableUpgradeHelper.js +52 -0
  190. package/src/migration/VersionUpgrade.d.ts +8 -0
  191. package/src/migration/VersionUpgrade.js +15 -0
  192. package/src/migration/VersionUpgrade17.d.ts +18 -0
  193. package/src/migration/VersionUpgrade17.js +347 -0
  194. package/src/migration/VersionUpgrade18.d.ts +5 -0
  195. package/src/migration/VersionUpgrade18.js +10 -0
  196. package/src/types.d.ts +7 -3
  197. package/tsconfig.cjs.tsbuildinfo +1 -1
  198. package/src/Utilities/Defaults/DefaultAdaptableOptions.d.ts +0 -2
  199. package/src/Utilities/Services/Interface/IRowEditService.d.ts +0 -3
  200. package/src/Utilities/Services/Interface/IRowEditService.js +0 -2
  201. package/src/agGrid/agGridHelper.d.ts +0 -57
  202. package/src/agGrid/agGridHelper.js +0 -691
  203. package/src/agGrid/agGridMenuHelper.d.ts +0 -46
  204. package/src/agGrid/agGridMenuHelper.js +0 -673
  205. /package/src/AdaptableOptions/{CommentsOptions.js → CommentOptions.js} +0 -0
  206. /package/src/AdaptableOptions/{NotesOptions.js → NoteOptions.js} +0 -0
@@ -0,0 +1,28 @@
1
+ import { AdaptableAgGrid } from './AdaptableAgGrid';
2
+ import { Column, GetContextMenuItems, GetContextMenuItemsParams, GetMainMenuItems, GetMainMenuItemsParams, MenuItemDef } from '@ag-grid-community/core';
3
+ import { AdaptableColumn } from '../PredefinedConfig/Common/AdaptableColumn';
4
+ import { AdaptableMenuItem, ColumnMenuContext } from '../PredefinedConfig/Common/Menu';
5
+ export declare class AgGridMenuAdapter {
6
+ private adaptableInstance;
7
+ constructor(adaptableInstance: AdaptableAgGrid);
8
+ private get adaptableOptions();
9
+ private get adaptableApi();
10
+ destroy(): void;
11
+ buildColumnMenu(params: GetMainMenuItemsParams, originalGetMainMenuItems: GetMainMenuItems): (string | MenuItemDef)[];
12
+ buildStructuredAdaptableColumnItems(menuContext: ColumnMenuContext): {
13
+ adaptableMenuItems: AdaptableMenuItem[];
14
+ structuredAdaptableMenuItems: AdaptableMenuItem[];
15
+ };
16
+ buildContextMenu(params: GetContextMenuItemsParams, originalGetContextMenuItems: GetContextMenuItems): (string | MenuItemDef)[];
17
+ createColumnMenuContextObject(adaptableColumn: AdaptableColumn, agGridColumn: Column): ColumnMenuContext;
18
+ private createAdaptableContextMenuItems;
19
+ private createContextMenuContextObject;
20
+ private mapAdaptableMenuItemToAgGridMenuDefinition;
21
+ private mapCustomMenuItemToAgGridMenuDefinition;
22
+ private mapUserMenuItemToAgGridMenuDefinition;
23
+ private buildGroupedModuleItems;
24
+ private mapAdaptableMenuItemToSystemMenuItems;
25
+ private createAdaptableColumnMenuItems;
26
+ private mapAdaptableIconToAgGridIcon;
27
+ buildStandaloneColumnHeader(adaptableColumn: AdaptableColumn): AdaptableMenuItem[];
28
+ }
@@ -0,0 +1,276 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AgGridMenuAdapter = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const MenuOptions_1 = require("../AdaptableOptions/MenuOptions");
6
+ const Icon_1 = require("../components/Icon");
7
+ const icons_1 = require("../components/icons");
8
+ const ArrayExtensions_1 = tslib_1.__importDefault(require("../Utilities/Extensions/ArrayExtensions"));
9
+ class AgGridMenuAdapter {
10
+ constructor(adaptableInstance) {
11
+ this.adaptableInstance = adaptableInstance;
12
+ }
13
+ get adaptableOptions() {
14
+ return this.adaptableInstance.adaptableOptions;
15
+ }
16
+ get adaptableApi() {
17
+ return this.adaptableInstance.api;
18
+ }
19
+ destroy() {
20
+ this.adaptableInstance = null;
21
+ }
22
+ buildColumnMenu(params, originalGetMainMenuItems) {
23
+ var _a;
24
+ const menuOptions = this.adaptableOptions.menuOptions;
25
+ const agGridMenuItems = (params.defaultItems ? [...params.defaultItems] : []);
26
+ if (!params.column) {
27
+ // return only AG Grid context if the Adaptable column is not found (should not happen)
28
+ return agGridMenuItems;
29
+ }
30
+ const adaptableColumn = this.adaptableApi.columnApi.getColumnWithColumnId((_a = params.column) === null || _a === void 0 ? void 0 : _a.getColId());
31
+ const menuContext = this.createColumnMenuContextObject(adaptableColumn, params.column);
32
+ const { adaptableMenuItems, structuredAdaptableMenuItems } = this.buildStructuredAdaptableColumnItems(menuContext);
33
+ // 1. first check if there is a custom column menu defined
34
+ if (typeof menuOptions.customColumnMenu === 'function') {
35
+ const defaultAgGridMenuItems = agGridMenuItems.map((itemName) => ({
36
+ menuType: 'AgGrid',
37
+ name: itemName,
38
+ }));
39
+ const defaultAdaptableMenuItems = adaptableMenuItems.map((adaptableItem) => (Object.assign({ menuType: 'Adaptable' }, adaptableItem)));
40
+ const customMenuItems = menuOptions
41
+ .customColumnMenu(Object.assign(Object.assign({}, menuContext), { defaultAgGridMenuItems,
42
+ defaultAdaptableMenuItems, structuredAdaptableMenuItems: this.mapAdaptableMenuItemToSystemMenuItems(structuredAdaptableMenuItems) }))
43
+ .filter(Boolean);
44
+ return customMenuItems
45
+ .map((customMenuItem) => this.mapCustomMenuItemToAgGridMenuDefinition(customMenuItem, menuContext))
46
+ .filter(Boolean);
47
+ }
48
+ // 2. if not, return the default context menu
49
+ const defaultContextMenu = [
50
+ ...agGridMenuItems,
51
+ 'separator',
52
+ ...structuredAdaptableMenuItems.map((adaptableItem) => this.mapAdaptableMenuItemToAgGridMenuDefinition(adaptableItem)),
53
+ ];
54
+ return defaultContextMenu;
55
+ }
56
+ buildStructuredAdaptableColumnItems(menuContext) {
57
+ const adaptableMenuItems = this.createAdaptableColumnMenuItems(menuContext);
58
+ // sort Adaptable menu items by default order
59
+ const structuredAdaptableMenuItems = this.buildGroupedModuleItems(MenuOptions_1.DEFAULT_ADAPTABLE_COLUMN_MENU_STRUCTURE, adaptableMenuItems);
60
+ return { adaptableMenuItems, structuredAdaptableMenuItems };
61
+ }
62
+ buildContextMenu(params, originalGetContextMenuItems) {
63
+ var _a;
64
+ // we do this in order to refresh the internal state of selected cells (technically query the AG Grid cellRanges)
65
+ // (right-click selected the current cell, but this was not reflected in the internal state of the selected cells)
66
+ this.adaptableInstance.refreshSelectedCellsState();
67
+ const menuOptions = this.adaptableOptions.menuOptions;
68
+ const agGridMenuItems = (params.defaultItems ? [...params.defaultItems] : []);
69
+ if (!params.column) {
70
+ // return only AG Grid context if the Adaptable column is not found (should not happen)
71
+ return agGridMenuItems;
72
+ }
73
+ const adaptableColumn = this.adaptableApi.columnApi.getColumnWithColumnId((_a = params.column) === null || _a === void 0 ? void 0 : _a.getColId());
74
+ const menuContext = this.createContextMenuContextObject(params, adaptableColumn);
75
+ const adaptableMenuItems = this.createAdaptableContextMenuItems(menuContext);
76
+ // sort Adaptable menu items by default order
77
+ const structuredAdaptableMenuItems = this.buildGroupedModuleItems(MenuOptions_1.DEFAULT_ADAPTABLE_CONTEXT_MENU_STRUCTURE, adaptableMenuItems);
78
+ // 1. first check if there is a custom context menu defined
79
+ if (typeof menuOptions.customContextMenu === 'function') {
80
+ const defaultAgGridMenuItems = agGridMenuItems.map((itemName) => ({
81
+ menuType: 'AgGrid',
82
+ name: itemName,
83
+ }));
84
+ const defaultAdaptableMenuItems = adaptableMenuItems.map((adaptableItem) => (Object.assign({ menuType: 'Adaptable' }, adaptableItem)));
85
+ const customMenuItems = menuOptions
86
+ .customContextMenu(Object.assign(Object.assign({}, menuContext), { defaultAgGridMenuItems,
87
+ defaultAdaptableMenuItems, structuredAdaptableMenuItems: this.mapAdaptableMenuItemToSystemMenuItems(structuredAdaptableMenuItems) }))
88
+ .filter(Boolean);
89
+ return customMenuItems
90
+ .map((customMenuItem) => this.mapCustomMenuItemToAgGridMenuDefinition(customMenuItem, menuContext))
91
+ .filter(Boolean);
92
+ }
93
+ // 2. if not, return the default context menu
94
+ const defaultContextMenu = [
95
+ ...agGridMenuItems,
96
+ 'separator',
97
+ ...structuredAdaptableMenuItems.map((adaptableItem) => this.mapAdaptableMenuItemToAgGridMenuDefinition(adaptableItem)),
98
+ ];
99
+ return defaultContextMenu;
100
+ }
101
+ createColumnMenuContextObject(adaptableColumn, agGridColumn) {
102
+ return Object.assign(Object.assign({}, this.adaptableInstance.api.internalApi.buildBaseContext()), { adaptableColumn: adaptableColumn, agGridColumn: agGridColumn, isRowGroupColumn: this.adaptableInstance.api.columnApi.isAutoRowGroupColumn(agGridColumn.getColId()) });
103
+ }
104
+ createAdaptableContextMenuItems(menuContext) {
105
+ let contextMenuItems = [];
106
+ this.adaptableInstance.adaptableModules.forEach((module) => {
107
+ let menuItems = module.addContextMenuItems(menuContext);
108
+ if (menuItems) {
109
+ contextMenuItems.push(...menuItems.filter(Boolean).filter((item) => item.isVisible !== false));
110
+ }
111
+ });
112
+ this.adaptableInstance._emitSync('CreateAdaptableContextMenuItems', {
113
+ items: contextMenuItems,
114
+ menuContext: menuContext,
115
+ });
116
+ return contextMenuItems;
117
+ }
118
+ createContextMenuContextObject(params, adaptableColumn) {
119
+ // lets build a picture of what has been right clicked. Will take time to get right but lets start
120
+ let isSingleSelectedColumn = false;
121
+ let isSelectedCell = false;
122
+ let isSelectedRow = false;
123
+ // row group columns dont provide an AdapTable Column so return bare minimum
124
+ if (!adaptableColumn) {
125
+ return Object.assign(Object.assign({}, this.adaptableApi.internalApi.buildBaseContext()), { isSelectedCell: false, isSelectedRow: false, gridCell: undefined, adaptableColumn: undefined, agGridColumn: params.column, rowNode: params.node, isGroupedNode: params.node ? params.node.group : false, isSingleSelectedColumn: false, isSingleSelectedCell: false, primaryKeyValue: undefined, selectedCellInfo: undefined, selectedRowInfo: undefined, isRowGroupColumn: this.adaptableApi.columnApi.isAutoRowGroupColumn(params.column.getColId()) });
126
+ }
127
+ const clickedCell = this.adaptableInstance.getGridCellFromRowNode(params.node, adaptableColumn.columnId);
128
+ const selectedCellInfo = this.adaptableApi.gridApi.getSelectedCellInfo();
129
+ if (selectedCellInfo) {
130
+ let matchedCell = selectedCellInfo.gridCells.find((gc) => gc != null &&
131
+ gc.column == clickedCell.column &&
132
+ gc.primaryKeyValue == clickedCell.primaryKeyValue);
133
+ isSelectedCell = matchedCell != null;
134
+ if (isSelectedCell) {
135
+ isSingleSelectedColumn = ArrayExtensions_1.default.CorrectLength(selectedCellInfo.columns, 1);
136
+ }
137
+ }
138
+ const selectedRowInfo = this.adaptableApi.gridApi.getSelectedRowInfo();
139
+ if (selectedRowInfo) {
140
+ const matchedPKValue = selectedRowInfo.gridRows.find((gr) => gr != null && gr.primaryKeyValue == clickedCell.primaryKeyValue);
141
+ isSelectedRow = matchedPKValue != null;
142
+ }
143
+ return Object.assign(Object.assign({}, this.adaptableApi.internalApi.buildBaseContext()), { isSelectedCell: isSelectedCell, isSelectedRow: isSelectedRow, gridCell: clickedCell, adaptableColumn: adaptableColumn, agGridColumn: params.column, rowNode: params.node, isGroupedNode: params.node ? params.node.group : false, isSingleSelectedColumn: isSingleSelectedColumn, isSingleSelectedCell: isSelectedCell && (selectedCellInfo === null || selectedCellInfo === void 0 ? void 0 : selectedCellInfo.gridCells.length) == 1, primaryKeyValue: clickedCell ? clickedCell.primaryKeyValue : undefined, selectedCellInfo: selectedCellInfo, selectedRowInfo: selectedRowInfo, isRowGroupColumn: this.adaptableApi.columnApi.isAutoRowGroupColumn(params.column.getColId()) });
144
+ }
145
+ mapAdaptableMenuItemToAgGridMenuDefinition(adaptableMenuItem) {
146
+ var _a;
147
+ return {
148
+ name: adaptableMenuItem.label,
149
+ action: adaptableMenuItem.onClick
150
+ ? adaptableMenuItem.onClick
151
+ : adaptableMenuItem.reduxAction
152
+ ? () => this.adaptableInstance.api.internalApi.dispatchReduxAction(adaptableMenuItem.reduxAction)
153
+ : undefined,
154
+ icon: this.mapAdaptableIconToAgGridIcon(adaptableMenuItem.icon, {
155
+ fill: 'var(--ab-color-text-on-primary)',
156
+ }),
157
+ subMenu: (_a = adaptableMenuItem.subItems) === null || _a === void 0 ? void 0 : _a.map((subMenuItem) => this.mapAdaptableMenuItemToAgGridMenuDefinition(subMenuItem)),
158
+ };
159
+ }
160
+ mapCustomMenuItemToAgGridMenuDefinition(customMenuItem, menuContext) {
161
+ var _a;
162
+ if (customMenuItem === '-') {
163
+ return 'separator';
164
+ }
165
+ if (customMenuItem.menuType === 'Group') {
166
+ return {
167
+ name: customMenuItem.label,
168
+ icon: this.mapAdaptableIconToAgGridIcon(customMenuItem.icon, {
169
+ fill: 'var(--ab-color-text-on-primary)',
170
+ }),
171
+ disabled: customMenuItem.disabled,
172
+ subMenu: !customMenuItem.disabled
173
+ ? (_a = customMenuItem.subMenuItems) === null || _a === void 0 ? void 0 : _a.map((subMenuItem) => this.mapCustomMenuItemToAgGridMenuDefinition(subMenuItem, menuContext)).filter(Boolean)
174
+ : undefined,
175
+ };
176
+ }
177
+ if (customMenuItem.menuType === 'AgGrid') {
178
+ return customMenuItem.name;
179
+ }
180
+ if (customMenuItem.menuType === 'Adaptable') {
181
+ return this.mapAdaptableMenuItemToAgGridMenuDefinition(customMenuItem);
182
+ }
183
+ if (customMenuItem.menuType === 'User') {
184
+ return this.mapUserMenuItemToAgGridMenuDefinition(customMenuItem, menuContext);
185
+ }
186
+ }
187
+ mapUserMenuItemToAgGridMenuDefinition(userMenuItem, menuContext) {
188
+ var _a;
189
+ if (userMenuItem.hidden) {
190
+ return;
191
+ }
192
+ return {
193
+ name: userMenuItem.label,
194
+ action: () => (userMenuItem.onClick ? userMenuItem.onClick(menuContext) : null),
195
+ icon: this.mapAdaptableIconToAgGridIcon(userMenuItem.icon, {
196
+ fill: 'var(--ab-color-text-on-primary)',
197
+ }),
198
+ disabled: userMenuItem.disabled,
199
+ subMenu: (_a = userMenuItem.subMenuItems) === null || _a === void 0 ? void 0 : _a.map((subMenuItem) => {
200
+ return this.mapCustomMenuItemToAgGridMenuDefinition(subMenuItem, menuContext);
201
+ }).filter(Boolean),
202
+ };
203
+ }
204
+ buildGroupedModuleItems(sortedMenuItems, adaptableMenuItems) {
205
+ return sortedMenuItems
206
+ .map((moduleOrGroup) => {
207
+ if (typeof moduleOrGroup === 'object') {
208
+ const submenuItems = this.buildGroupedModuleItems(moduleOrGroup.modules, adaptableMenuItems);
209
+ // if there is only one item in the submenu, we don't need to show the submenu
210
+ if (submenuItems.length === 1) {
211
+ return submenuItems[0];
212
+ }
213
+ return {
214
+ label: moduleOrGroup.title,
215
+ icon: moduleOrGroup.icon,
216
+ subItems: submenuItems,
217
+ };
218
+ }
219
+ else {
220
+ return adaptableMenuItems.find((menuItem) => menuItem.module === moduleOrGroup);
221
+ }
222
+ })
223
+ .filter((menuItem) => {
224
+ if (!menuItem) {
225
+ return false;
226
+ }
227
+ if (menuItem.subItems && menuItem.subItems.length === 0) {
228
+ return false;
229
+ }
230
+ return true;
231
+ });
232
+ }
233
+ mapAdaptableMenuItemToSystemMenuItems(adaptableMenuItems) {
234
+ return (adaptableMenuItems !== null && adaptableMenuItems !== void 0 ? adaptableMenuItems : []).map((menuItem) => {
235
+ let subItems = menuItem.subItems;
236
+ if (subItems && subItems.length > 0) {
237
+ subItems = subItems.map((subItem) => this.mapAdaptableMenuItemToSystemMenuItems(subItem.subItems));
238
+ }
239
+ return Object.assign(Object.assign({}, menuItem), { menuType: 'Adaptable', subItems });
240
+ });
241
+ }
242
+ createAdaptableColumnMenuItems(menuContext) {
243
+ let contextMenuItems = [];
244
+ this.adaptableInstance.adaptableModules.forEach((s) => {
245
+ let menuItems = s.addColumnMenuItems(menuContext.adaptableColumn);
246
+ if (menuItems) {
247
+ contextMenuItems.push(...menuItems.filter(Boolean).filter((item) => item.isVisible !== false));
248
+ }
249
+ });
250
+ return contextMenuItems;
251
+ }
252
+ // TODO AFL MIG: pretty sure this logic is duplicated in several other places
253
+ mapAdaptableIconToAgGridIcon(adaptableIcon, style) {
254
+ const icon = this.adaptableInstance.api.userInterfaceApi.internalApi.prepareAdaptableIconDef(adaptableIcon);
255
+ if ((0, Icon_1.isAdaptableElementIcon)(icon)) {
256
+ let element = icon.element;
257
+ if (typeof element === 'string') {
258
+ return element;
259
+ }
260
+ // THe element neets to be cloned.
261
+ // when it is used in more than one plce the element is removed from the DOM
262
+ return element.cloneNode(true);
263
+ }
264
+ else {
265
+ return (0, icons_1.iconToString)(icon, {
266
+ fill: 'var(--ab-color-text-on-primary)',
267
+ });
268
+ }
269
+ }
270
+ buildStandaloneColumnHeader(adaptableColumn) {
271
+ const agGridColumn = this.adaptableInstance.getAgGridColumnForColumnId(adaptableColumn.columnId);
272
+ const menuContext = this.createColumnMenuContextObject(adaptableColumn, agGridColumn);
273
+ return this.buildStructuredAdaptableColumnItems(menuContext).adaptableMenuItems;
274
+ }
275
+ }
276
+ exports.AgGridMenuAdapter = AgGridMenuAdapter;
@@ -0,0 +1,11 @@
1
+ import { AdaptableAgGrid } from './AdaptableAgGrid';
2
+ import { GridOptions } from '@ag-grid-community/core';
3
+ export declare class AgGridOptionsService {
4
+ private adaptableInstance;
5
+ private gridOptionsPropertyCache;
6
+ private colDefPropertyCache;
7
+ constructor(adaptableInstance: AdaptableAgGrid);
8
+ destroy(): void;
9
+ setGridOptionsProperty<T extends keyof GridOptions>(gridOptions: GridOptions, propertyName: T, propertyGetter: (userPropertyValue: GridOptions[T]) => GridOptions[T] | undefined): GridOptions;
10
+ revertGridOptionsPropertiesToUserValue<T extends keyof GridOptions>(gridOptions: GridOptions, propertyNames: T[]): void;
11
+ }
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AgGridOptionsService = void 0;
4
+ class AgGridOptionsService {
5
+ constructor(adaptableInstance) {
6
+ this.adaptableInstance = adaptableInstance;
7
+ this.gridOptionsPropertyCache = new Map();
8
+ this.colDefPropertyCache = new Map();
9
+ }
10
+ destroy() {
11
+ this.gridOptionsPropertyCache.clear();
12
+ this.colDefPropertyCache.clear();
13
+ this.gridOptionsPropertyCache = null;
14
+ this.colDefPropertyCache = null;
15
+ }
16
+ setGridOptionsProperty(gridOptions, propertyName, propertyGetter) {
17
+ if (this.adaptableInstance.lifecycleState === 'preDestroyed') {
18
+ return;
19
+ }
20
+ const userKey = `user.${propertyName}`;
21
+ const adaptableKey = `adaptable.${propertyName}`;
22
+ const value = gridOptions[propertyName];
23
+ const isUserDefined = value !== this.gridOptionsPropertyCache.get(adaptableKey);
24
+ if (isUserDefined) {
25
+ this.gridOptionsPropertyCache.set(userKey, value);
26
+ }
27
+ const userValue = this.gridOptionsPropertyCache.get(userKey);
28
+ let adaptableValue = propertyGetter(userValue);
29
+ if (typeof adaptableValue === 'function') {
30
+ const previousValue = adaptableValue;
31
+ // @ts-ignore we know that adaptableValue is a function
32
+ adaptableValue = (...args) => {
33
+ if (this.adaptableInstance.isDestroyed) {
34
+ return;
35
+ }
36
+ return previousValue(...args);
37
+ };
38
+ }
39
+ if (adaptableValue != null) {
40
+ this.gridOptionsPropertyCache.set(adaptableKey, adaptableValue);
41
+ }
42
+ gridOptions[propertyName] = adaptableValue !== null && adaptableValue !== void 0 ? adaptableValue : userValue;
43
+ return gridOptions;
44
+ }
45
+ revertGridOptionsPropertiesToUserValue(gridOptions, propertyNames) {
46
+ for (const propertyName of propertyNames) {
47
+ // see this.setGridOptionsProperty(...)
48
+ const userKey = `user.${propertyName}`;
49
+ const userValue = this.gridOptionsPropertyCache.get(userKey);
50
+ gridOptions[propertyName] = userValue;
51
+ }
52
+ }
53
+ }
54
+ exports.AgGridOptionsService = AgGridOptionsService;
@@ -11,7 +11,7 @@ const getBadgeRendererForColumn = (styledColumn, abColumn, api) => {
11
11
  }
12
12
  return class BadgetRenderer {
13
13
  getAdaptableInstance(params) {
14
- const adaptable = params.api.__adaptable;
14
+ const adaptable = params.context.__adaptable;
15
15
  return adaptable;
16
16
  }
17
17
  init(params) {
@@ -69,7 +69,7 @@ class CheckboxEditor {
69
69
  // however, using ReactUI makes some race conditions possible, in which cases the editor will be displayed for a few milliseconds
70
70
  // we provide this logic for those few cases (to avoid a flicker effect)
71
71
  init(params) {
72
- const adaptable = params.api.__adaptable;
72
+ const adaptable = params.context.__adaptable;
73
73
  const inputElement = document.createElement('input');
74
74
  inputElement.type = 'checkbox';
75
75
  inputElement.checked = params.value;
@@ -1,2 +1,2 @@
1
- import { Adaptable } from './Adaptable';
2
- export declare let FilterWrapperFactory: (adaptable: Adaptable) => any;
1
+ import { AdaptableAgGrid } from './AdaptableAgGrid';
2
+ export declare const FilterWrapperFactory: (adaptable: AdaptableAgGrid) => any;
@@ -5,7 +5,7 @@ const tslib_1 = require("tslib");
5
5
  const React = tslib_1.__importStar(require("react"));
6
6
  const react_1 = require("react");
7
7
  const FilterForm_1 = require("../View/Components/FilterForm/FilterForm");
8
- let FilterWrapperFactory = (adaptable) => {
8
+ const FilterWrapperFactory = (adaptable) => {
9
9
  function isFilterActive(colId) {
10
10
  // we need this here
11
11
  if (adaptable.isDestroyed) {
@@ -1,16 +1,16 @@
1
1
  import { GridOptions } from '@ag-grid-community/core';
2
2
  export declare const attachColumnTypes: (gridOptions: GridOptions) => {
3
- [key: string]: import("@ag-grid-community/core").ColDef<any, any>;
3
+ [key: string]: import("@ag-grid-community/core").ColTypeDef<any, any>;
4
4
  } & {
5
- [x: string]: import("@ag-grid-community/core").ColDef<any, any>;
6
- abColDefNumber: import("@ag-grid-community/core").ColDef<any, any>;
7
- abColDefString: import("@ag-grid-community/core").ColDef<any, any>;
8
- abColDefBoolean: import("@ag-grid-community/core").ColDef<any, any>;
9
- abColDefDate: import("@ag-grid-community/core").ColDef<any, any>;
10
- abColDefObject: import("@ag-grid-community/core").ColDef<any, any>;
11
- abColDefCustom: import("@ag-grid-community/core").ColDef<any, any>;
12
- abColDefStringArray: import("@ag-grid-community/core").ColDef<any, any>;
13
- abColDefNumberArray: import("@ag-grid-community/core").ColDef<any, any>;
14
- abColDefTupleNumberArray: import("@ag-grid-community/core").ColDef<any, any>;
15
- abColDefObjectNumberArray: import("@ag-grid-community/core").ColDef<any, any>;
5
+ [x: string]: import("@ag-grid-community/core").ColTypeDef<any, any>;
6
+ abColDefNumber: import("@ag-grid-community/core").ColTypeDef<any, any>;
7
+ abColDefString: import("@ag-grid-community/core").ColTypeDef<any, any>;
8
+ abColDefBoolean: import("@ag-grid-community/core").ColTypeDef<any, any>;
9
+ abColDefDate: import("@ag-grid-community/core").ColTypeDef<any, any>;
10
+ abColDefObject: import("@ag-grid-community/core").ColTypeDef<any, any>;
11
+ abColDefCustom: import("@ag-grid-community/core").ColTypeDef<any, any>;
12
+ abColDefStringArray: import("@ag-grid-community/core").ColTypeDef<any, any>;
13
+ abColDefNumberArray: import("@ag-grid-community/core").ColTypeDef<any, any>;
14
+ abColDefTupleNumberArray: import("@ag-grid-community/core").ColTypeDef<any, any>;
15
+ abColDefObjectNumberArray: import("@ag-grid-community/core").ColTypeDef<any, any>;
16
16
  };
@@ -0,0 +1,3 @@
1
+ import { AdaptableOptions } from '../AdaptableOptions/AdaptableOptions';
2
+ export declare function applyDefaultAdaptableOptions(adaptableOptions: AdaptableOptions): AdaptableOptions;
3
+ export declare const getDefaultAdaptableOptions: () => AdaptableOptions<any>;
@@ -1,19 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DefaultAdaptableOptions = void 0;
3
+ exports.getDefaultAdaptableOptions = exports.applyDefaultAdaptableOptions = void 0;
4
4
  const tslib_1 = require("tslib");
5
- const GeneralConstants = tslib_1.__importStar(require("../Constants/GeneralConstants"));
6
- const GeneralConstants_1 = require("../Constants/GeneralConstants");
7
- const UIHelper_1 = tslib_1.__importStar(require("../../View/UIHelper"));
8
- const AdaptablePredicate_1 = require("../../PredefinedConfig/Common/AdaptablePredicate");
9
- const Enums_1 = require("../../PredefinedConfig/Common/Enums");
10
- const ModuleConstants = tslib_1.__importStar(require("../../Utilities/Constants/ModuleConstants"));
11
- // change type to DeepRequired<AdaptableOptions> to check which properties have no default values defined
12
- exports.DefaultAdaptableOptions = {
5
+ const GeneralConstants = tslib_1.__importStar(require("../Utilities/Constants/GeneralConstants"));
6
+ const UIHelper_1 = tslib_1.__importStar(require("../View/UIHelper"));
7
+ const GeneralConstants_1 = require("../Utilities/Constants/GeneralConstants");
8
+ const Enums_1 = require("../PredefinedConfig/Common/Enums");
9
+ const AdaptablePredicate_1 = require("../PredefinedConfig/Common/AdaptablePredicate");
10
+ const ModuleConstants = tslib_1.__importStar(require("../Utilities/Constants/ModuleConstants"));
11
+ const AdaptableHelper_1 = require("../Utilities/Helpers/AdaptableHelper");
12
+ const DefaultAdaptableOptions = {
13
13
  adaptableId: GeneralConstants.ADAPTABLE_ID,
14
14
  adaptableStateKey: undefined,
15
15
  primaryKey: '',
16
16
  autogeneratePrimaryKey: false,
17
+ autoMigrateState: true,
17
18
  userName: GeneralConstants.USER_NAME,
18
19
  predefinedConfig: undefined,
19
20
  alertOptions: {
@@ -201,7 +202,7 @@ exports.DefaultAdaptableOptions = {
201
202
  sortValuesFilter: false,
202
203
  filterValuesUsingTime: false,
203
204
  showDistinctFilteredValuesOnly: false,
204
- maxFilterValuesToDisplay: 2000,
205
+ maxFilterValuesToDisplay: undefined,
205
206
  includeBlankFilterValues: false,
206
207
  showValuesCount: undefined,
207
208
  },
@@ -272,6 +273,9 @@ exports.DefaultAdaptableOptions = {
272
273
  useCustomMacLikeScrollbars: false,
273
274
  englishVariant: 'GB',
274
275
  showLoadingScreen: true,
276
+ loadingScreenDelay: 200,
277
+ loadingScreenTitle: 'Initialising Grid',
278
+ loadingScreenText: 'Retrieving your settings and setting up the grid...',
275
279
  disableDeleteConfirmation: false,
276
280
  dateInputOptions: {
277
281
  useNativeInput: false,
@@ -329,3 +333,62 @@ exports.DefaultAdaptableOptions = {
329
333
  },
330
334
  },
331
335
  };
336
+ function applyDefaultAdaptableOptions(adaptableOptions) {
337
+ var _a;
338
+ const adaptableOptsWithDefaults = Object.assign({}, DefaultAdaptableOptions, adaptableOptions);
339
+ adaptableOptsWithDefaults.adaptableStateKey =
340
+ (_a = adaptableOptsWithDefaults.adaptableStateKey) !== null && _a !== void 0 ? _a : adaptableOptsWithDefaults.adaptableId;
341
+ adaptableOptsWithDefaults.dataImportOptions = Object.assign({}, DefaultAdaptableOptions.dataImportOptions, adaptableOptions.dataImportOptions);
342
+ adaptableOptsWithDefaults.expressionOptions = Object.assign({}, DefaultAdaptableOptions.expressionOptions, adaptableOptions.expressionOptions);
343
+ adaptableOptsWithDefaults.calendarOptions = Object.assign({}, DefaultAdaptableOptions.calendarOptions, adaptableOptions.calendarOptions);
344
+ adaptableOptsWithDefaults.columnOptions = Object.assign({}, DefaultAdaptableOptions.columnOptions, adaptableOptions.columnOptions);
345
+ adaptableOptsWithDefaults.customSortOptions = Object.assign({}, DefaultAdaptableOptions.customSortOptions, adaptableOptions.customSortOptions);
346
+ adaptableOptsWithDefaults.dataSetOptions = Object.assign({}, DefaultAdaptableOptions.dataSetOptions, adaptableOptions.dataSetOptions);
347
+ adaptableOptsWithDefaults.cellSummaryOptions = Object.assign({}, DefaultAdaptableOptions.cellSummaryOptions, adaptableOptions.cellSummaryOptions);
348
+ adaptableOptsWithDefaults.predicateOptions = Object.assign({}, DefaultAdaptableOptions.predicateOptions, adaptableOptsWithDefaults.predicateOptions);
349
+ adaptableOptsWithDefaults.layoutOptions = Object.assign({}, DefaultAdaptableOptions.layoutOptions, adaptableOptions.layoutOptions);
350
+ adaptableOptsWithDefaults.notificationsOptions = Object.assign({}, DefaultAdaptableOptions.notificationsOptions, adaptableOptions.notificationsOptions);
351
+ adaptableOptsWithDefaults.alertOptions = Object.assign({}, DefaultAdaptableOptions.alertOptions, adaptableOptions.alertOptions);
352
+ adaptableOptsWithDefaults.flashingCellOptions = Object.assign({}, DefaultAdaptableOptions.flashingCellOptions, adaptableOptions.flashingCellOptions);
353
+ adaptableOptsWithDefaults.entitlementOptions = Object.assign({}, DefaultAdaptableOptions.entitlementOptions, adaptableOptions.entitlementOptions);
354
+ adaptableOptsWithDefaults.dashboardOptions = Object.assign({}, DefaultAdaptableOptions.dashboardOptions, adaptableOptions.dashboardOptions);
355
+ adaptableOptsWithDefaults.editOptions = Object.assign({}, DefaultAdaptableOptions.editOptions, adaptableOptions.editOptions);
356
+ adaptableOptsWithDefaults.actionColumnOptions = Object.assign({}, DefaultAdaptableOptions.actionColumnOptions, adaptableOptions.actionColumnOptions);
357
+ // to do
358
+ adaptableOptsWithDefaults.actionRowOptions = Object.assign({}, DefaultAdaptableOptions.actionRowOptions, adaptableOptions.actionRowOptions);
359
+ adaptableOptsWithDefaults.actionRowOptions.actionRowButtonOptions = Object.assign({}, DefaultAdaptableOptions.actionRowOptions.actionRowButtonOptions, adaptableOptsWithDefaults.actionRowOptions.actionRowButtonOptions);
360
+ adaptableOptsWithDefaults.actionRowOptions.actionRowFormOptions = Object.assign({}, DefaultAdaptableOptions.actionRowOptions.actionRowFormOptions, adaptableOptsWithDefaults.actionRowOptions.actionRowFormOptions);
361
+ adaptableOptsWithDefaults.containerOptions = Object.assign({}, DefaultAdaptableOptions.containerOptions, adaptableOptions.containerOptions);
362
+ adaptableOptsWithDefaults.groupingOptions = Object.assign({}, DefaultAdaptableOptions.groupingOptions, adaptableOptions.groupingOptions);
363
+ adaptableOptsWithDefaults.quickSearchOptions = Object.assign({}, DefaultAdaptableOptions.quickSearchOptions, adaptableOptions.quickSearchOptions);
364
+ adaptableOptsWithDefaults.columnFilterOptions = Object.assign({}, DefaultAdaptableOptions.columnFilterOptions, adaptableOptions.columnFilterOptions);
365
+ adaptableOptsWithDefaults.columnFilterOptions.quickFilterOptions = Object.assign({}, DefaultAdaptableOptions.columnFilterOptions.quickFilterOptions, adaptableOptsWithDefaults.columnFilterOptions.quickFilterOptions);
366
+ adaptableOptsWithDefaults.columnFilterOptions.filterFormOptions = Object.assign({}, DefaultAdaptableOptions.columnFilterOptions.filterFormOptions, adaptableOptsWithDefaults.columnFilterOptions.filterFormOptions);
367
+ adaptableOptsWithDefaults.columnFilterOptions.valuesFilterOptions = Object.assign({}, DefaultAdaptableOptions.columnFilterOptions.valuesFilterOptions, adaptableOptsWithDefaults.columnFilterOptions.valuesFilterOptions);
368
+ adaptableOptsWithDefaults.gridFilterOptions = Object.assign({}, DefaultAdaptableOptions.gridFilterOptions, adaptableOptions.gridFilterOptions);
369
+ adaptableOptsWithDefaults.userInterfaceOptions = Object.assign({}, DefaultAdaptableOptions.userInterfaceOptions, adaptableOptions.userInterfaceOptions);
370
+ adaptableOptsWithDefaults.userInterfaceOptions.dateInputOptions = Object.assign({}, DefaultAdaptableOptions.userInterfaceOptions.dateInputOptions, adaptableOptsWithDefaults.userInterfaceOptions.dateInputOptions);
371
+ adaptableOptsWithDefaults.menuOptions = Object.assign({}, DefaultAdaptableOptions.menuOptions, adaptableOptions.menuOptions);
372
+ adaptableOptsWithDefaults.stateOptions = Object.assign({}, DefaultAdaptableOptions.stateOptions, adaptableOptions.stateOptions);
373
+ adaptableOptsWithDefaults.exportOptions = Object.assign({}, DefaultAdaptableOptions.exportOptions, adaptableOptions.exportOptions);
374
+ adaptableOptsWithDefaults.teamSharingOptions = Object.assign({}, DefaultAdaptableOptions.teamSharingOptions, adaptableOptions.teamSharingOptions);
375
+ adaptableOptsWithDefaults.toolPanelOptions = Object.assign({}, DefaultAdaptableOptions.toolPanelOptions, adaptableOptions.toolPanelOptions);
376
+ adaptableOptsWithDefaults.dataChangeHistoryOptions = Object.assign({}, DefaultAdaptableOptions.dataChangeHistoryOptions, adaptableOptions.dataChangeHistoryOptions);
377
+ adaptableOptsWithDefaults.chartingOptions = Object.assign({}, DefaultAdaptableOptions.chartingOptions, adaptableOptions.chartingOptions);
378
+ adaptableOptsWithDefaults.chartingOptions.externalChartingOptions = Object.assign({}, DefaultAdaptableOptions.chartingOptions.externalChartingOptions, adaptableOptsWithDefaults.chartingOptions.externalChartingOptions);
379
+ adaptableOptsWithDefaults.settingsPanelOptions = Object.assign({}, DefaultAdaptableOptions.settingsPanelOptions, adaptableOptions.settingsPanelOptions);
380
+ adaptableOptsWithDefaults.fdc3Options = Object.assign({}, DefaultAdaptableOptions.fdc3Options, adaptableOptions.fdc3Options);
381
+ adaptableOptsWithDefaults.fdc3Options.actionColumnDefaultConfiguration = Object.assign({}, DefaultAdaptableOptions.fdc3Options.actionColumnDefaultConfiguration, adaptableOptsWithDefaults.fdc3Options.actionColumnDefaultConfiguration);
382
+ adaptableOptsWithDefaults.fdc3Options.uiControlsDefaultConfiguration = Object.assign({}, DefaultAdaptableOptions.fdc3Options.uiControlsDefaultConfiguration, adaptableOptsWithDefaults.fdc3Options.uiControlsDefaultConfiguration);
383
+ const { predefinedConfig } = adaptableOptsWithDefaults;
384
+ if (predefinedConfig) {
385
+ adaptableOptsWithDefaults.predefinedConfig =
386
+ typeof predefinedConfig === 'string'
387
+ ? predefinedConfig
388
+ : (0, AdaptableHelper_1.initPredefinedConfigWithUuids)(predefinedConfig);
389
+ }
390
+ return adaptableOptsWithDefaults;
391
+ }
392
+ exports.applyDefaultAdaptableOptions = applyDefaultAdaptableOptions;
393
+ const getDefaultAdaptableOptions = () => DefaultAdaptableOptions;
394
+ exports.getDefaultAdaptableOptions = getDefaultAdaptableOptions;
@@ -33,7 +33,7 @@ exports.ReactAdaptableDateEditor = (0, react_1.forwardRef)((props, ref) => {
33
33
  const valueRef = (0, react_1.useRef)(initialValue);
34
34
  const colValueParser = props.column.getColDef().valueParser;
35
35
  const valueParser = typeof colValueParser === 'function' ? colValueParser : defaultDateValueParser;
36
- const adaptable = props.api.__adaptable;
36
+ const adaptable = props.context.__adaptable;
37
37
  const editorRef = (0, react_1.useRef)(null);
38
38
  (0, react_1.useImperativeHandle)(ref, () => {
39
39
  return {
@@ -139,7 +139,7 @@ class AdaptableDateEditor {
139
139
  }
140
140
  focusOut() { }
141
141
  getAdaptableInstance(params) {
142
- const adaptable = params.api.__adaptable;
142
+ const adaptable = params.context.__adaptable;
143
143
  return adaptable;
144
144
  }
145
145
  // after this component has been created and inserted into the grid
@@ -39,7 +39,7 @@ exports.ReactAdaptableNumberEditor = (0, react_1.forwardRef)((props, ref) => {
39
39
  const [initialValue] = (0, react_1.useState)(() => getStartValue(props));
40
40
  const valueRef = (0, react_1.useRef)(initialValue);
41
41
  const columnId = props.column.getColId();
42
- const adaptable = props.api.__adaptable;
42
+ const adaptable = props.context.__adaptable;
43
43
  const colValueParser = props.column.getColDef().valueParser;
44
44
  const valueParser = typeof colValueParser === 'function' ? colValueParser : defaultValueParser;
45
45
  function onValueChange(value) {
@@ -138,7 +138,7 @@ class AdaptableNumberEditor {
138
138
  // after this component has been created and inserted into the grid
139
139
  afterGuiAttached() {
140
140
  var _a, _b;
141
- const adaptable = this.params.api.__adaptable;
141
+ const adaptable = this.params.context.__adaptable;
142
142
  const defaultValue = this.value;
143
143
  const editorElement = (React.createElement(InternalAdaptableNumberEditor_1.InternalAdaptableNumberEditor, { defaultValue: defaultValue, showClearButton: (_a = this.params.showClearButton) !== null && _a !== void 0 ? _a : true, emptyValue: (_b = this.params.emptyValue) !== null && _b !== void 0 ? _b : '', onValueChange: this.onValueChange, ref: (editor) => {
144
144
  this.editor = editor;