ods-component-lib 1.18.164 → 1.18.166

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 (49) hide show
  1. package/dist/components/antd/form/OdsBasicForm.d.ts +18 -0
  2. package/dist/components/antd/icon/OdsIcon.d.ts +10 -0
  3. package/dist/components/antd/select/OdsCustomMultiSelect.d.ts +7 -0
  4. package/dist/components/antd/select/OdsMultiSelect.d.ts +9 -0
  5. package/dist/components/antd/slider/OdsSlider.d.ts +2 -2
  6. package/dist/components/antd/slider/OdsTwoHandleSlider.d.ts +9 -0
  7. package/dist/components/antd/timeline/OdsTimeline.d.ts +2 -2
  8. package/dist/components/custom/OdsLogin.d.ts +8 -0
  9. package/dist/components/devextreme/DxDataPopupForm.d.ts +3 -0
  10. package/dist/components/devextreme/DynamicIcon.d.ts +5 -0
  11. package/dist/components/devextreme/OdsDataGridNew.d.ts +56 -0
  12. package/dist/components/devextreme/OdsInlineEditDataGrid/handlers/ContentHandlers.d.ts +14 -0
  13. package/dist/components/devextreme/OdsInlineEditDataGrid/handlers/EditorPreparedHandlers.d.ts +7 -0
  14. package/dist/components/devextreme/OdsInlineEditDataGrid/handlers/OnExportingHandlers.d.ts +19 -0
  15. package/dist/components/devextreme/OdsInlineEditDataGrid/handlers/OptionHandlers.d.ts +7 -0
  16. package/dist/components/devextreme/OdsInlineEditDataGrid/handlers/SummaryHandlers.d.ts +21 -0
  17. package/dist/components/devextreme/OdsInlineEditDataGrid/partials/ActionCellRender.d.ts +15 -0
  18. package/dist/components/devextreme/OdsInlineEditDataGrid/partials/EditingPartial.d.ts +9 -0
  19. package/dist/components/devextreme/OdsInlineEditDataGrid/partials/PageTitle.d.ts +8 -0
  20. package/dist/components/devextreme/OdsInlineEditDataGrid/utils.d.ts +19 -0
  21. package/dist/components/devextreme/OdsMasterDetailDataGrid/OdsMasterDetailDataGrid.d.ts +4 -0
  22. package/dist/components/devextreme/OdsMasterDetailDataGrid/handlers/OnActionButtons.d.ts +9 -0
  23. package/dist/components/devextreme/OdsMasterDetailDataGrid/handlers/OnActionCellRenderHandler.d.ts +11 -0
  24. package/dist/components/devextreme/OdsMasterDetailDataGrid/handlers/OnExportingHandler.d.ts +10 -0
  25. package/dist/components/devextreme/OdsMasterDetailDataGrid/types.d.ts +91 -0
  26. package/dist/components/devextreme/OdsProfDataGrid.d.ts +3 -0
  27. package/dist/components/devextreme/OdsServerSideTransfer.d.ts +56 -0
  28. package/dist/components/devextreme/dataGridHandlers/OnToolbarButtonHandler.d.ts +7 -0
  29. package/dist/components/devextreme/dataGridStyle.d.ts +3 -0
  30. package/dist/components/devextreme/treeview/DxTreeView.d.ts +3 -0
  31. package/dist/index.css +53 -0
  32. package/dist/index.d.ts +2 -0
  33. package/dist/index.js +213 -140
  34. package/dist/index.js.map +1 -1
  35. package/dist/index.modern.js +213 -141
  36. package/dist/index.modern.js.map +1 -1
  37. package/dist/stories/OdsCustomMultiSelect/OdsCustomMultiSelect.stories.d.ts +9 -0
  38. package/dist/stories/OdsCustomMultiSelect/Samples/Basic.Sample.d.ts +1 -0
  39. package/dist/stories/OdsCustomMultiSelect/Samples/ModeMultiple.Sample.d.ts +1 -0
  40. package/dist/stories/OdsSlider/OdsSlider.stories.d.ts +1 -0
  41. package/dist/stories/OdsSlider/Samples/TwoHandleSlider.d.ts +2 -0
  42. package/dist/stories/OdsTimeline/OdsTimeline.stories.d.ts +4 -42
  43. package/dist/stories/OdsTimeline/Samples/TimelineVertical.Sample.d.ts +2 -0
  44. package/dist/utils/DynamicIcon.d.ts +5 -0
  45. package/package.json +1 -1
  46. package/dist/stories/OdsPivotGrid/OdsPivotGrid.stories.d.ts +0 -15
  47. package/dist/stories/OdsPivotGrid/Samples/BasicPivotGrid/BasicPivotGrid.Constants.d.ts +0 -2
  48. package/dist/stories/OdsPivotGrid/Samples/BasicPivotGrid/BasicPivotGrid.MockData.d.ts +0 -7
  49. package/dist/stories/OdsPivotGrid/Samples/BasicPivotGrid/BasicPivotGrid.Sample.d.ts +0 -1
package/dist/index.js CHANGED
@@ -79,37 +79,6 @@ function _taggedTemplateLiteralLoose(strings, raw) {
79
79
  strings.raw = raw;
80
80
  return strings;
81
81
  }
82
- function _unsupportedIterableToArray(o, minLen) {
83
- if (!o) return;
84
- if (typeof o === "string") return _arrayLikeToArray(o, minLen);
85
- var n = Object.prototype.toString.call(o).slice(8, -1);
86
- if (n === "Object" && o.constructor) n = o.constructor.name;
87
- if (n === "Map" || n === "Set") return Array.from(o);
88
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
89
- }
90
- function _arrayLikeToArray(arr, len) {
91
- if (len == null || len > arr.length) len = arr.length;
92
- for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
93
- return arr2;
94
- }
95
- function _createForOfIteratorHelperLoose(o, allowArrayLike) {
96
- var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
97
- if (it) return (it = it.call(o)).next.bind(it);
98
- if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
99
- if (it) o = it;
100
- var i = 0;
101
- return function () {
102
- if (i >= o.length) return {
103
- done: true
104
- };
105
- return {
106
- done: false,
107
- value: o[i++]
108
- };
109
- };
110
- }
111
- throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
112
- }
113
82
 
114
83
  var _templateObject;
115
84
  var StyledAlert = styled__default(antd.Alert)(_templateObject || (_templateObject = _taggedTemplateLiteralLoose(["\n //\n"])));
@@ -1114,7 +1083,9 @@ var _templateObject$l;
1114
1083
  var StyledtTimeline = styled__default(antd.Timeline)(_templateObject$l || (_templateObject$l = _taggedTemplateLiteralLoose(["\n //\n"])));
1115
1084
 
1116
1085
  function OdsTimeline(props) {
1117
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(StyledtTimeline, Object.assign({}, props), props.children));
1086
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(StyledtTimeline, Object.assign({}, props, {
1087
+ mode: props.mode
1088
+ })));
1118
1089
  }
1119
1090
 
1120
1091
  var _templateObject$m;
@@ -33736,6 +33707,7 @@ var OdsBasicDataGrid = function OdsBasicDataGrid(props) {
33736
33707
  key: col.dataField
33737
33708
  }, col, {
33738
33709
  minWidth: 50,
33710
+ width: 160,
33739
33711
  cssClass: col.cssClass + " " + (hasFastUpdate ? "grid-cell-disable-text-selection" : "")
33740
33712
  }), col.lookUp && React__default.createElement(devextremeReact.Lookup, Object.assign({}, col.lookUp)), (col.dataField === "IsActive" || col.dataField === "isActive") && React__default.createElement(DataGrid.HeaderFilter, {
33741
33713
  dataSource: [{
@@ -34533,12 +34505,6 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34533
34505
  updateTrigger = _useState4[0],
34534
34506
  setUpdateTrigger = _useState4[1];
34535
34507
  var lastPageIndexRef = React.useRef(null);
34536
- var _useState5 = React.useState({}),
34537
- filterOptions = _useState5[0],
34538
- setFilterOptions = _useState5[1];
34539
- var _useState6 = React.useState([]),
34540
- headerFilterData = _useState6[0],
34541
- setHeaderFilterData = _useState6[1];
34542
34508
  var _useStyles = useStyles$1(),
34543
34509
  gridStyle = _useStyles.styles;
34544
34510
  var renderTotal = React.useCallback(function () {
@@ -34562,46 +34528,12 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34562
34528
  var currentPageIndex = dataGridInstance.pageCount();
34563
34529
  var currentTotalCount = currentPageIndex == 0 ? 50 : dataGridInstance.totalCount();
34564
34530
  var newData = dataGridInstance === null || dataGridInstance === void 0 ? void 0 : (_dataGridInstance$get = dataGridInstance.getDataSource()) === null || _dataGridInstance$get === void 0 ? void 0 : _dataGridInstance$get.items();
34531
+ if (filterApplied) {
34532
+ totalFilteredCount.current = currentTotalCount;
34533
+ } else {
34534
+ totalUnfilteredCount.current = currentTotalCount;
34535
+ }
34565
34536
  if ((!filterApplied && currentPageIndex == 1 && currentTotalCount != totalUnfilteredCount.current || lastPageIndexRef.current !== currentPageIndex) && newData && newData.length > 0) {
34566
- setHeaderFilterData(function (prevData) {
34567
- var uniqueValuesByColumn = {};
34568
- props.columns.forEach(function (col) {
34569
- uniqueValuesByColumn[col.dataField] = new Set(prevData.map(function (item) {
34570
- return item[col.dataField];
34571
- }).filter(function (val) {
34572
- return val !== null && val !== "";
34573
- }));
34574
- });
34575
- var newItems = [];
34576
- newData.forEach(function (item) {
34577
- var addItem = {};
34578
- props.columns.forEach(function (col) {
34579
- var _item$col$dataField;
34580
- var colValue = (_item$col$dataField = item[col.dataField]) === null || _item$col$dataField === void 0 ? void 0 : _item$col$dataField.toString();
34581
- if (props.applyCellRenderToHeaderFilter) {
34582
- try {
34583
- if (col.cellRender) {
34584
- colValue = col.cellRender({
34585
- value: colValue
34586
- });
34587
- } else if (col.calculateCellValue) {
34588
- var _q;
34589
- var q = (_q = {}, _q[col.dataField] = item[col.dataField], _q);
34590
- colValue = col.calculateCellValue(q);
34591
- }
34592
- } catch (error) {}
34593
- }
34594
- if (colValue && !uniqueValuesByColumn[col.dataField].has(colValue)) {
34595
- uniqueValuesByColumn[col.dataField].add(colValue);
34596
- addItem[col.dataField] = colValue;
34597
- }
34598
- });
34599
- if (Object.keys(addItem).length > 0) {
34600
- newItems.push(addItem);
34601
- }
34602
- });
34603
- return [].concat(prevData, newItems);
34604
- });
34605
34537
  setCurrentPage(currentPageIndex);
34606
34538
  setCurrentPageSize(dataGridInstance.pageSize());
34607
34539
  rowCount.current = currentTotalCount;
@@ -34610,16 +34542,6 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34610
34542
  });
34611
34543
  lastPageIndexRef.current = currentPageIndex;
34612
34544
  }
34613
- if (currentTotalCount > 0) {
34614
- if (filterApplied) {
34615
- totalFilteredCount.current = currentTotalCount;
34616
- } else {
34617
- totalUnfilteredCount.current = currentTotalCount;
34618
- }
34619
- if (!filterApplied && totalFilteredCount.current === 0) {
34620
- totalFilteredCount.current = totalUnfilteredCount.current;
34621
- }
34622
- }
34623
34545
  }, [props.columns, filterApplied]);
34624
34546
  var handleOptionChanged = React.useCallback(function (e) {
34625
34547
  var dataGrid = props.dataGridRef.current.instance;
@@ -34650,45 +34572,6 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34650
34572
  }
34651
34573
  }, [props.dataGridRef]);
34652
34574
  React.useEffect(function () {}, [updateTrigger]);
34653
- React.useEffect(function () {
34654
- var loadFilterData = function loadFilterData() {
34655
- try {
34656
- var newFilterOptions = {};
34657
- var _loop = function _loop() {
34658
- var col = _step.value;
34659
- try {
34660
- if (headerFilterData.length > 0) {
34661
- var newData = headerFilterData.filter(function (item) {
34662
- return item[col.dataField] != null && item[col.dataField] !== "";
34663
- }).map(function (item) {
34664
- return item[col.dataField].toString();
34665
- });
34666
- var values = newData.map(function (group) {
34667
- return {
34668
- text: group,
34669
- value: group
34670
- };
34671
- });
34672
- newFilterOptions[col.dataField] = values;
34673
- }
34674
- } catch (error) {
34675
- console.error('Error loading data for header filter:', error);
34676
- }
34677
- };
34678
- for (var _iterator = _createForOfIteratorHelperLoose(props.columns), _step; !(_step = _iterator()).done;) {
34679
- _loop();
34680
- }
34681
- setFilterOptions(newFilterOptions);
34682
- return Promise.resolve();
34683
- } catch (e) {
34684
- return Promise.reject(e);
34685
- }
34686
- };
34687
- loadFilterData();
34688
- }, [headerFilterData, props.columns]);
34689
- React.useEffect(function () {
34690
- setHeaderFilterData([]);
34691
- }, []);
34692
34575
  var actionButtons = React.useMemo(function () {
34693
34576
  if (props.actionButtonGroup) {
34694
34577
  if (props.actionButtonGroup.length > 3 && !props.edit) {
@@ -34827,7 +34710,7 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34827
34710
  focusedRowEnabled: false,
34828
34711
  onEditorPrepared: onEditorPrepared,
34829
34712
  onCellClick: function onCellClick(e) {
34830
- if (e.rowType != 'header') {
34713
+ if (e.rowType != "header") {
34831
34714
  e.cellElement.style.backgroundColor = "transparent";
34832
34715
  }
34833
34716
  },
@@ -34879,7 +34762,8 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34879
34762
  return React__default.createElement(DataGrid.Column, Object.assign({
34880
34763
  key: col.dataField
34881
34764
  }, col, {
34882
- minWidth: 10
34765
+ minWidth: 10,
34766
+ width: 160
34883
34767
  }), col.lookUp && React__default.createElement(devextremeReact.Lookup, Object.assign({}, col.lookUp)), col.dataField === "IsActive" && React__default.createElement(DataGrid.HeaderFilter, {
34884
34768
  dataSource: [{
34885
34769
  text: "Active",
@@ -34888,9 +34772,9 @@ var OdsServerSideDatagrid = function OdsServerSideDatagrid(props) {
34888
34772
  text: "Passive",
34889
34773
  value: false
34890
34774
  }]
34891
- }), React__default.createElement(DataGrid.HeaderFilter, {
34892
- dataSource: [].concat(filterOptions[col.dataField] || [])
34893
- }), col.multiLevelColumns && col.multiLevelColumns.map(function (multiLevelColItem) {
34775
+ }), col.headerFilter && React__default.createElement(DataGrid.HeaderFilter, Object.assign({}, col.headerFilter, {
34776
+ visible: true
34777
+ })), col.multiLevelColumns && col.multiLevelColumns.map(function (multiLevelColItem) {
34894
34778
  return React__default.createElement(DataGrid.Column, {
34895
34779
  dataField: multiLevelColItem.dataField,
34896
34780
  caption: multiLevelColItem.caption,
@@ -35042,17 +34926,17 @@ var useOnContentReadyHandler = function useOnContentReadyHandler(columns, lastPa
35042
34926
  var currentPageIndex = dataGridInstance.pageIndex();
35043
34927
  var currentTotalCount = dataGridInstance.totalCount();
35044
34928
  var newData = dataGridInstance === null || dataGridInstance === void 0 ? void 0 : (_dataGridInstance$get = dataGridInstance.getDataSource()) === null || _dataGridInstance$get === void 0 ? void 0 : _dataGridInstance$get.items();
34929
+ if (filterApplied) {
34930
+ totalFilteredCount.current = currentTotalCount;
34931
+ } else {
34932
+ totalUnfilteredCount.current = currentTotalCount;
34933
+ }
34934
+ if (!filterApplied && totalFilteredCount.current === 0) {
34935
+ totalFilteredCount.current = totalUnfilteredCount.current;
34936
+ }
35045
34937
  if (lastPageIndexRef.current !== currentPageIndex && newData && newData.length > 0) {
35046
34938
  setCurrentPage(currentPageIndex);
35047
34939
  setCurrentPageSize(dataGridInstance.pageSize());
35048
- if (filterApplied) {
35049
- totalFilteredCount.current = currentTotalCount;
35050
- } else {
35051
- totalUnfilteredCount.current = currentTotalCount;
35052
- }
35053
- if (!filterApplied && totalFilteredCount.current === 0) {
35054
- totalFilteredCount.current = totalUnfilteredCount.current;
35055
- }
35056
34940
  setUpdateTrigger(function (prev) {
35057
34941
  return !prev;
35058
34942
  });
@@ -35300,7 +35184,8 @@ var OdsInlineEditDataGrid = function OdsInlineEditDataGrid(props) {
35300
35184
  return React__default.createElement(DataGrid.Column, Object.assign({
35301
35185
  key: col.dataField
35302
35186
  }, col, {
35303
- minWidth: 10
35187
+ minWidth: 10,
35188
+ width: 160
35304
35189
  }), col.lookup && React__default.createElement(DataGrid.Lookup, Object.assign({}, col.lookup)), col.headerFilter && React__default.createElement(DataGrid.HeaderFilter, Object.assign({}, col.headerFilter, {
35305
35190
  visible: true,
35306
35191
  allowSearch: true
@@ -35392,6 +35277,193 @@ var OdsInlineEditDataGrid = function OdsInlineEditDataGrid(props) {
35392
35277
  }, React__default.createElement("p", null, renderTotal())));
35393
35278
  };
35394
35279
 
35280
+ var useOnActionCellRenderHandler$1 = function useOnActionCellRenderHandler(visibleActionButtons, actionButtonGroup, edit, actionButtonsTooltipType) {
35281
+ var onActionCellRender = React.useCallback(function (cellData) {
35282
+ if (!cellData || !visibleActionButtons) return null;
35283
+ var kebabMenuButtons = actionButtonGroup && actionButtonGroup.length >= 2 && !edit ? actionButtonGroup.slice(2).map(function (button) {
35284
+ return {
35285
+ icon: button.icon,
35286
+ onClick: function onClick(event) {
35287
+ var customEvent = {
35288
+ column: cellData.column,
35289
+ component: cellData.component,
35290
+ element: cellData.element,
35291
+ event: event,
35292
+ model: cellData.data,
35293
+ row: cellData.row
35294
+ };
35295
+ button.onClick(customEvent);
35296
+ }
35297
+ };
35298
+ }) : [];
35299
+ var buttonElements = visibleActionButtons.map(function (buttonItem) {
35300
+ var isVisible = typeof buttonItem.visible === "function" ? buttonItem.visible({
35301
+ column: cellData.column,
35302
+ component: cellData.component,
35303
+ row: cellData.row
35304
+ }) : buttonItem.visible;
35305
+ return React__default.createElement(OdsDataGrdiRowButton, Object.assign({
35306
+ key: "action-button-" + buttonItem.name,
35307
+ name: buttonItem.name,
35308
+ hint: buttonItem.hint,
35309
+ visible: isVisible,
35310
+ size: "small",
35311
+ type: "text",
35312
+ disabled: buttonItem.actionPermission === undefined ? false : !buttonItem.actionPermission,
35313
+ icon: buttonItem.icon
35314
+ }, actionButtonsTooltipType === "styled" && {
35315
+ tooltip: buttonItem.hint
35316
+ }, {
35317
+ onClick: function onClick(event) {
35318
+ if (buttonItem.onClick) {
35319
+ var customEvent = {
35320
+ column: cellData.column,
35321
+ component: cellData.component,
35322
+ element: cellData.element,
35323
+ event: event,
35324
+ model: cellData.data,
35325
+ row: cellData.row
35326
+ };
35327
+ buttonItem.onClick(customEvent);
35328
+ }
35329
+ }
35330
+ }));
35331
+ });
35332
+ if (kebabMenuButtons.length > 0) {
35333
+ buttonElements.push(React__default.createElement(OdsDropdown, {
35334
+ key: "dropdown-" + (cellData.rowIndex || cellData.data.ID),
35335
+ menuItems: kebabMenuButtons
35336
+ }, React__default.createElement(OdsDataGrdiRowButton, {
35337
+ type: "text",
35338
+ icon: React__default.createElement(DynamicIcon, {
35339
+ iconName: "kebabMenu"
35340
+ })
35341
+ })));
35342
+ }
35343
+ return React__default.createElement(React__default.Fragment, null, buttonElements);
35344
+ }, [visibleActionButtons]);
35345
+ return onActionCellRender;
35346
+ };
35347
+
35348
+ var useOnExportingHandler$1 = function useOnExportingHandler(exportProps, getSummary, callback) {
35349
+ var onExporting = React.useCallback(function (e) {
35350
+ if (exportProps) {
35351
+ var _exportProps$fileName, _exportProps$activeTe, _exportProps$passiveT;
35352
+ ExportDataGridToExcel({
35353
+ gridComponent: e.component,
35354
+ baseFileName: (_exportProps$fileName = exportProps.fileName) != null ? _exportProps$fileName : "DataGrid",
35355
+ selectedText: exportProps.selectedText,
35356
+ getSummary: getSummary,
35357
+ selectedRowsOnly: e.selectedRowsOnly,
35358
+ activeText: (_exportProps$activeTe = exportProps.activeText) != null ? _exportProps$activeTe : "Active",
35359
+ passiveText: (_exportProps$passiveT = exportProps.passiveText) != null ? _exportProps$passiveT : "Passive"
35360
+ });
35361
+ }
35362
+ if (callback) {
35363
+ callback(e);
35364
+ }
35365
+ }, [getSummary]);
35366
+ return onExporting;
35367
+ };
35368
+
35369
+ var MasterDetailDataGrid = function MasterDetailDataGrid(_ref) {
35370
+ var columns = _ref.columns,
35371
+ dataSource = _ref.dataSource,
35372
+ _ref$masterDetailFeat = _ref.masterDetailFeatures,
35373
+ masterDetailFeatures = _ref$masterDetailFeat === void 0 ? {} : _ref$masterDetailFeat,
35374
+ masterDetailData = _ref.masterDetailData;
35375
+ var visibleActionButtons = React.useMemo(function () {
35376
+ if (masterDetailFeatures.masterActionButtonGroup && masterDetailFeatures.masterActionButtonGroup.length >= 2) {
35377
+ return masterDetailFeatures.masterActionButtonGroup.slice(0, 2);
35378
+ }
35379
+ return masterDetailFeatures.masterActionButtonGroup || [];
35380
+ }, [masterDetailFeatures.masterActionButtonGroup]);
35381
+ var onActionCellRender = useOnActionCellRenderHandler$1(visibleActionButtons, masterDetailFeatures.masterActionButtonGroup);
35382
+ var getTotalDataCount = function getTotalDataCount() {
35383
+ return "" + dataSource.length;
35384
+ };
35385
+ var handleExporting = useOnExportingHandler$1(masterDetailFeatures.exportProps, getTotalDataCount);
35386
+ var effectiveColumns = (masterDetailData === null || masterDetailData === void 0 ? void 0 : masterDetailData.detailGridColumns) || columns || (dataSource[0] ? Object.keys(dataSource[0]).map(function (key) {
35387
+ return {
35388
+ dataField: key,
35389
+ caption: key.charAt(0).toUpperCase() + key.slice(1),
35390
+ allowFiltering: true
35391
+ };
35392
+ }) : []);
35393
+ return React__default.createElement(DataGrid__default, {
35394
+ style: {
35395
+ maxHeight: masterDetailFeatures.maxHeight ? masterDetailFeatures.maxHeight + "px" : "400px",
35396
+ overflow: "auto"
35397
+ },
35398
+ dataSource: dataSource,
35399
+ showBorders: true,
35400
+ columnAutoWidth: true,
35401
+ allowColumnReordering: true,
35402
+ selection: {
35403
+ mode: masterDetailFeatures.showCheckbox ? "multiple" : "none"
35404
+ },
35405
+ paging: {
35406
+ enabled: true,
35407
+ pageSize: masterDetailFeatures.pageSize || 20
35408
+ },
35409
+ filterRow: {
35410
+ visible: masterDetailFeatures.createFilter
35411
+ },
35412
+ onExporting: handleExporting,
35413
+ onToolbarPreparing: masterDetailFeatures.detailToolbar
35414
+ }, effectiveColumns.map(function (col) {
35415
+ return React__default.createElement(DataGrid.Column, Object.assign({
35416
+ key: col.dataField
35417
+ }, col, {
35418
+ headerFilter: {
35419
+ visible: col.allowFiltering
35420
+ }
35421
+ }));
35422
+ }), React__default.createElement(DataGrid.ColumnChooser, {
35423
+ enabled: masterDetailFeatures.columnChooser,
35424
+ mode: "select"
35425
+ }, React__default.createElement(DataGrid.Position, {
35426
+ my: "right top",
35427
+ at: "right bottom",
35428
+ of: document.querySelector("." + "props.dataGridPageName") ? "." + "props.dataGridPageName" + " .dx-datagrid-column-chooser-button" : ".dx-datagrid-column-chooser-button"
35429
+ }), React__default.createElement(DataGrid.ColumnChooserSearch, {
35430
+ enabled: true,
35431
+ editorOptions: {
35432
+ placeholder: ""
35433
+ }
35434
+ }), React__default.createElement(DataGrid.HeaderFilter, {
35435
+ visible: true
35436
+ }), React__default.createElement(DataGrid.ColumnChooserSelection, {
35437
+ allowSelectAll: true,
35438
+ selectByClick: true,
35439
+ recursive: true
35440
+ })), (masterDetailFeatures === null || masterDetailFeatures === void 0 ? void 0 : masterDetailFeatures.exportEnabled) && React__default.createElement(DataGrid.Export, Object.assign({}, masterDetailFeatures.exportProps)), masterDetailFeatures.actionColumnEnable && React__default.createElement(DataGrid.Column, {
35441
+ dataField: "Actions",
35442
+ caption: "",
35443
+ minWidth: 10,
35444
+ width: 160,
35445
+ fixed: true,
35446
+ allowSorting: false,
35447
+ type: "buttons",
35448
+ showInColumnChooser: false,
35449
+ cellRender: onActionCellRender
35450
+ }), React__default.createElement(DataGrid.FilterRow, {
35451
+ visible: masterDetailFeatures.createFilter
35452
+ }), React__default.createElement(DataGrid.Selection, {
35453
+ mode: masterDetailFeatures.showCheckbox ? "multiple" : "none"
35454
+ }), React__default.createElement(DataGrid.SearchPanel, {
35455
+ visible: masterDetailFeatures.showSearchPanel
35456
+ }), React__default.createElement(DataGrid.Toolbar, null, React__default.createElement(DataGrid.Item, {
35457
+ name: "searchPanel"
35458
+ }), React__default.createElement(DataGrid.Item, {
35459
+ name: "columnChooserButton",
35460
+ cssClass: "toolbarPanelItems"
35461
+ }), React__default.createElement(DataGrid.Item, {
35462
+ name: "exportButton",
35463
+ cssClass: "toolbarPanelItems"
35464
+ })));
35465
+ };
35466
+
35395
35467
  /**
35396
35468
  * Checks if `value` is the
35397
35469
  * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
@@ -37070,6 +37142,7 @@ exports.OdsInput = OdsInput;
37070
37142
  exports.OdsInputNumber = OdsInputNumber;
37071
37143
  exports.OdsLink = OdsLink;
37072
37144
  exports.OdsList = OdsList;
37145
+ exports.OdsMasterDetailDataGrid = MasterDetailDataGrid;
37073
37146
  exports.OdsModal = OdsModal;
37074
37147
  exports.OdsModalOld = OdsModalOld;
37075
37148
  exports.OdsMultiSelect = OdsMultiSelect;