@commercetools-uikit/data-table-manager 19.9.0 → 19.10.0

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 (31) hide show
  1. package/README.md +50 -35
  2. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.d.ts +2 -0
  3. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.dev.js +43 -0
  4. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.js +7 -0
  5. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.prod.js +43 -0
  6. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.esm.js +35 -0
  7. package/column-settings-manager/package.json +4 -0
  8. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.dev.js +6 -4
  9. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.prod.js +6 -4
  10. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.esm.js +6 -4
  11. package/dist/column-settings-manager-1430ee4f.esm.js +463 -0
  12. package/dist/column-settings-manager-92b54563.cjs.dev.js +494 -0
  13. package/dist/column-settings-manager-b08669e8.cjs.prod.js +407 -0
  14. package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +142 -464
  15. package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +137 -383
  16. package/dist/commercetools-uikit-data-table-manager.esm.js +143 -454
  17. package/dist/{data-table-manager-provider-3f60b85b.esm.js → data-table-manager-provider-32eb58dd.esm.js} +41 -9
  18. package/dist/{data-table-manager-provider-6c690fc1.cjs.dev.js → data-table-manager-provider-c64c81aa.cjs.prod.js} +43 -10
  19. package/dist/{data-table-manager-provider-ddf7fb63.cjs.prod.js → data-table-manager-provider-fc238633.cjs.dev.js} +43 -10
  20. package/dist/declarations/src/column-settings-manager/column-settings-manager.d.ts +26 -0
  21. package/dist/declarations/src/column-settings-manager/export-types.d.ts +3 -0
  22. package/dist/declarations/src/column-settings-manager/index.d.ts +2 -0
  23. package/dist/declarations/src/constants.d.ts +2 -0
  24. package/dist/declarations/src/data-table-manager-provider/data-table-manager-provider.d.ts +11 -2
  25. package/dist/declarations/src/data-table-manager-provider/types.d.ts +62 -0
  26. package/dist/declarations/src/export-types.d.ts +2 -0
  27. package/dist/declarations/src/index.d.ts +1 -0
  28. package/dist/declarations/src/settings-container/index.d.ts +2 -0
  29. package/dist/declarations/src/settings-container/settings-container.d.ts +23 -0
  30. package/dist/declarations/src/types.d.ts +203 -2
  31. package/package.json +29 -25
@@ -1,3 +1,6 @@
1
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
2
+ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
3
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
1
4
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
2
5
  import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
3
6
  import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
@@ -6,18 +9,16 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
6
9
  import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
7
10
  import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
8
11
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
- import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
- import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
11
- import { useState, useMemo, useCallback, cloneElement } from 'react';
12
+ import { useState, useMemo, cloneElement } from 'react';
12
13
  import Spacings from '@commercetools-uikit/spacings';
13
14
  import { useDataTableManagerContext } from '@commercetools-uikit/data-table-manager/data-table-manager-provider';
14
15
  import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
15
- import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
16
16
  import _styled from '@emotion/styled/base';
17
+ import _Object$entries from '@babel/runtime-corejs3/core-js-stable/object/entries';
17
18
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
18
19
  import { warning } from '@commercetools-uikit/utils';
19
- import { useIntl, defineMessages } from 'react-intl';
20
- import { CloseIcon, EyeCrossedIcon, EyeIcon, SearchIcon, ColumnsIcon } from '@commercetools-uikit/icons';
20
+ import { defineMessages, useIntl } from 'react-intl';
21
+ import { ColumnsIcon } from '@commercetools-uikit/icons';
21
22
  import DropdownMenu from '@commercetools-uikit/dropdown-menu';
22
23
  import IconButton from '@commercetools-uikit/icon-button';
23
24
  import Tooltip from '@commercetools-uikit/tooltip';
@@ -27,119 +28,35 @@ import Grid from '@commercetools-uikit/grid';
27
28
  import RadioInput from '@commercetools-uikit/radio-input';
28
29
  import AccessibleHidden from '@commercetools-uikit/accessible-hidden';
29
30
  import { designTokens } from '@commercetools-uikit/design-system';
30
- import AccessibleButton from '@commercetools-uikit/accessible-button';
31
- import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
32
- import Card from '@commercetools-uikit/card';
33
- import Text from '@commercetools-uikit/text';
34
- import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
35
- import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
36
- import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
37
- import { Draggable, Droppable, DragDropContext } from 'react-beautiful-dnd';
38
- import debounce from 'debounce-promise';
39
- import differenceWith from 'lodash/differenceWith';
40
- import AsyncSelectInput from '@commercetools-uikit/async-select-input';
41
- import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
42
- import Tag from '@commercetools-uikit/tag';
31
+ import { S as SettingsContainer, C as ColumnSettingsManager } from './column-settings-manager-1430ee4f.esm.js';
32
+ export { C as ColumnSettingsManager } from './column-settings-manager-1430ee4f.esm.js';
43
33
  export { useRowSelection, useSorting } from '@commercetools-uikit/hooks';
44
- export { D as DataTableManagerProvider, u as useDataTableManagerContext } from './data-table-manager-provider-3f60b85b.esm.js';
34
+ export { D as DataTableManagerProvider, u as useDataTableManagerContext } from './data-table-manager-provider-32eb58dd.esm.js';
35
+ import '@babel/runtime-corejs3/core-js-stable/promise';
36
+ import '@babel/runtime-corejs3/core-js-stable/instance/slice';
37
+ import '@babel/runtime-corejs3/core-js-stable/instance/find';
38
+ import 'react-beautiful-dnd';
39
+ import 'debounce-promise';
40
+ import 'lodash/differenceWith';
41
+ import '@commercetools-uikit/async-select-input';
42
+ import '@commercetools-uikit/accessible-button';
43
+ import '@commercetools-uikit/collapsible-motion';
44
+ import '@commercetools-uikit/card';
45
+ import '@commercetools-uikit/text';
46
+ import '@babel/runtime-corejs3/core-js-stable/instance/concat';
47
+ import '@commercetools-uikit/tag';
45
48
 
46
49
  const UPDATE_ACTIONS = {
47
50
  COLUMNS_UPDATE: 'columnsUpdate',
51
+ CUSTOM_SETTINGS_UPDATE: 'customSettingsUpdate',
52
+ CUSTOM_COLUMNS_UPDATE: 'customColumnsUpdate',
48
53
  IS_TABLE_CONDENSED_UPDATE: 'isTableCondensedUpdate',
49
54
  IS_TABLE_WRAPPING_TEXT_UPDATE: 'isTableWrappingTextUpdate'
50
55
  };
51
56
  const COLUMN_MANAGER = 'columnManager';
52
57
  const DISPLAY_SETTINGS = 'displaySettings';
53
58
 
54
- function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
55
- const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
56
- target: "e6ezr101"
57
- } : {
58
- target: "e6ezr101",
59
- label: "HeaderContainer"
60
- })(process.env.NODE_ENV === "production" ? {
61
- name: "1bhm8h2",
62
- styles: "display:flex;flex:1;justify-content:space-between"
63
- } : {
64
- name: "1bhm8h2",
65
- styles: "display:flex;flex:1;justify-content:space-between",
66
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUU2V0dGluZ3NDb250YWluZXJQcm9wcyA9IHtcbiAgdGl0bGU6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIGNsb3NlQnV0dG9uTGFiZWw6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIG9uQ2xvc2U6IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIHByaW1hcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIHNlY29uZGFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgY29udGFpbmVyVGhlbWU/OiAnbGlnaHQnIHwgJ2RhcmsnO1xufTtcblxuY29uc3QgSGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcblxuY29uc3QgQ2FyZENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuYDtcblxuY29uc3QgU2V0dGluZ3NDb250YWluZXIgPSAocHJvcHM6IFRTZXR0aW5nc0NvbnRhaW5lclByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cInJhaXNlZFwiIGluc2V0U2NhbGU9XCJub25lXCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgyXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */",
67
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
68
- });
69
- const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
70
- target: "e6ezr100"
71
- } : {
72
- target: "e6ezr100",
73
- label: "CardContentWrapper"
74
- })("padding:", designTokens.spacing40, " ", designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUU2V0dGluZ3NDb250YWluZXJQcm9wcyA9IHtcbiAgdGl0bGU6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIGNsb3NlQnV0dG9uTGFiZWw6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIG9uQ2xvc2U6IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIHByaW1hcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIHNlY29uZGFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgY29udGFpbmVyVGhlbWU/OiAnbGlnaHQnIHwgJ2RhcmsnO1xufTtcblxuY29uc3QgSGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcblxuY29uc3QgQ2FyZENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuYDtcblxuY29uc3QgU2V0dGluZ3NDb250YWluZXIgPSAocHJvcHM6IFRTZXR0aW5nc0NvbnRhaW5lclByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cInJhaXNlZFwiIGluc2V0U2NhbGU9XCJub25lXCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgyXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */"));
75
- const SettingsContainer = props => {
76
- const intl = useIntl();
77
- return jsx(CollapsibleMotion, {
78
- isDefaultClosed: false,
79
- children: _ref => {
80
- let registerContentNode = _ref.registerContentNode,
81
- containerStyles = _ref.containerStyles;
82
- return jsx(Card, {
83
- type: "raised",
84
- insetScale: "none",
85
- theme: props.containerTheme,
86
- children: jsx(CardContentWrapper, {
87
- children: jsxs(Spacings.Stack, {
88
- scale: "xl",
89
- children: [jsxs(HeaderContainer, {
90
- children: [jsx(Text.Headline, {
91
- as: "h2",
92
- intlMessage: props.title
93
- }), jsx(AccessibleButton, {
94
- onClick: props.onClose,
95
- label: intl.formatMessage(props.closeButtonLabel),
96
- children: jsx(CloseIcon, {
97
- size: "medium"
98
- })
99
- })]
100
- }), jsxs(Spacings.Stack, {
101
- scale: "l",
102
- children: [jsx(Spacings.Inset, {
103
- scale: "s",
104
- children: jsx("div", {
105
- style: containerStyles,
106
- children: jsx("div", {
107
- ref: registerContentNode,
108
- children: props.children
109
- })
110
- })
111
- }), (props.secondaryButton || props.primaryButton) && jsxs(Spacings.Inline, {
112
- justifyContent: "flex-end",
113
- children: [props.secondaryButton, props.primaryButton]
114
- })]
115
- })]
116
- })
117
- })
118
- });
119
- }
120
- });
121
- };
122
- SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
123
- title: _pt.oneOfType([_pt.any, _pt.shape({
124
- values: _pt.objectOf(_pt.node)
125
- })]).isRequired,
126
- closeButtonLabel: _pt.oneOfType([_pt.any, _pt.shape({
127
- values: _pt.objectOf(_pt.node)
128
- })]).isRequired,
129
- onClose: _pt.func.isRequired,
130
- primaryButton: _pt.element,
131
- secondaryButton: _pt.element,
132
- children: _pt.node.isRequired,
133
- containerTheme: _pt.oneOf(['light', 'dark'])
134
- } : {};
135
- SettingsContainer.displayName = 'SettingsContainer';
136
- const defaultProps$2 = {
137
- containerTheme: 'dark'
138
- };
139
- SettingsContainer.defaultProps = defaultProps$2;
140
- var SettingsContainer$1 = SettingsContainer;
141
-
142
- var messages$3 = defineMessages({
59
+ var messages$2 = defineMessages({
143
60
  title: {
144
61
  id: 'UIKit.DataTableManager.DensityManager.title',
145
62
  description: 'Title for the density manager component.',
@@ -191,9 +108,10 @@ const DensityManager = props => {
191
108
  const intl = useIntl();
192
109
  const textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
193
110
  const densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_COMFORTABLE;
194
- return jsx(SettingsContainer$1, {
195
- title: messages$3.title,
196
- closeButtonLabel: messages$3.closeButtonLabel,
111
+ return jsx(SettingsContainer, {
112
+ customSettingsTitle: props.title,
113
+ title: messages$2.title,
114
+ closeButtonLabel: messages$2.closeButtonLabel,
197
115
  onClose: props.onClose,
198
116
  primaryButton: props.primaryButton,
199
117
  secondaryButton: props.secondaryButton,
@@ -205,7 +123,7 @@ const DensityManager = props => {
205
123
  children: jsxs(Spacings.Stack, {
206
124
  scale: 'l',
207
125
  children: [jsx(FieldLabel, {
208
- title: intl.formatMessage(messages$3.textWrappingSubtitle)
126
+ title: intl.formatMessage(messages$2.textWrappingSubtitle)
209
127
  }), jsxs(AccessibleHidden, {
210
128
  children: [jsx("label", {
211
129
  htmlFor: "text-wrapping-0",
@@ -221,10 +139,10 @@ const DensityManager = props => {
221
139
  onChange: props.onTextWrappingChange,
222
140
  children: [jsx(RadioInput.Option, {
223
141
  value: WRAPPED_TEXT_VISIBLE,
224
- children: intl.formatMessage(messages$3.textWrappingAllWrapVisibleOption)
142
+ children: intl.formatMessage(messages$2.textWrappingAllWrapVisibleOption)
225
143
  }), jsx(RadioInput.Option, {
226
144
  value: SHOW_HIDE_ON_DEMAND,
227
- children: intl.formatMessage(messages$3.textWrappingShowHideOnDemandOption)
145
+ children: intl.formatMessage(messages$2.textWrappingShowHideOnDemandOption)
228
146
  })]
229
147
  })]
230
148
  })
@@ -232,7 +150,7 @@ const DensityManager = props => {
232
150
  children: jsxs(Spacings.Stack, {
233
151
  scale: 'l',
234
152
  children: [jsx(FieldLabel, {
235
- title: intl.formatMessage(messages$3.densityDisplaySubtitle)
153
+ title: intl.formatMessage(messages$2.densityDisplaySubtitle)
236
154
  }), jsxs(AccessibleHidden, {
237
155
  children: [jsx("label", {
238
156
  htmlFor: "density-display-0",
@@ -248,10 +166,10 @@ const DensityManager = props => {
248
166
  onChange: props.onDensityDisplayChange,
249
167
  children: [jsx(RadioInput.Option, {
250
168
  value: DENSITY_COMFORTABLE,
251
- children: intl.formatMessage(messages$3.densityDisplayComfortableOption)
169
+ children: intl.formatMessage(messages$2.densityDisplayComfortableOption)
252
170
  }), jsx(RadioInput.Option, {
253
171
  value: DENSITY_COMPACT,
254
- children: intl.formatMessage(messages$3.densityDisplayCompactOption)
172
+ children: intl.formatMessage(messages$2.densityDisplayCompactOption)
255
173
  })]
256
174
  })]
257
175
  })
@@ -260,6 +178,7 @@ const DensityManager = props => {
260
178
  });
261
179
  };
262
180
  DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
181
+ title: _pt.string,
263
182
  isCondensed: _pt.bool,
264
183
  isWrappingText: _pt.bool,
265
184
  primaryButton: _pt.element,
@@ -270,344 +189,40 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
270
189
  managerTheme: _pt.oneOf(['light', 'dark'])
271
190
  } : {};
272
191
  DensityManager.displayName = 'DensityManager';
273
- const defaultProps$1 = {
192
+ const defaultProps = {
274
193
  isCondensed: true,
275
194
  isWrappingText: false
276
195
  };
277
- DensityManager.defaultProps = defaultProps$1;
196
+ DensityManager.defaultProps = defaultProps;
278
197
  var DisplaySettingsManager = DensityManager;
279
198
 
280
- function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
281
- const DraggingSmall = /*#__PURE__*/_styled("small", process.env.NODE_ENV === "production" ? {
282
- target: "e1mp438g1"
283
- } : {
284
- target: "e1mp438g1",
285
- label: "DraggingSmall"
286
- })(process.env.NODE_ENV === "production" ? {
287
- name: "1fhyj3b",
288
- styles: "&:hover{cursor:grab;}"
289
- } : {
290
- name: "1fhyj3b",
291
- styles: "&:hover{cursor:grab;}",
292
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFa0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */",
293
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
294
- });
295
- const DraggingContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
296
- target: "e1mp438g0"
297
- } : {
298
- target: "e1mp438g0",
299
- label: "DraggingContainer"
300
- })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRb0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */"));
301
- var DraggingContainer$1 = DraggingContainer;
302
-
303
- function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
304
- function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
305
- const DraggableTagWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
306
- target: "emzjy4n0"
307
- } : {
308
- target: "emzjy4n0",
309
- label: "DraggableTagWrapper"
310
- })("padding:", designTokens.spacing10, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbmV4cG9ydCB0eXBlIFRDb2x1bW5EYXRhID0ge1xuICBrZXk6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFREcmFnZ2FibGVUYWdQcm9wcyA9IHtcbiAgY29sdW1uOiBUQ29sdW1uRGF0YTtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIG9uUmVtb3ZlPzogKGluZGV4OiBudW1iZXIpID0+IHZvaWQ7XG59O1xuXG5jb25zdCBEcmFnZ2FibGVUYWdXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfSAwO1xuYDtcblxuY29uc3QgRHJhZ2dhYmxlVGFnID0gKHByb3BzOiBURHJhZ2dhYmxlVGFnUHJvcHMpID0+IHtcbiAgY29uc3QgaGFuZGxlUmVtb3ZlQ29sdW1uID0gKCkgPT4gcHJvcHMub25SZW1vdmU/Lihwcm9wcy5pbmRleCk7XG5cbiAgcmV0dXJuIChcbiAgICA8RHJhZ2dhYmxlXG4gICAgICBkcmFnZ2FibGVJZD17cHJvcHMuY29sdW1uLmtleX1cbiAgICAgIGluZGV4PXtwcm9wcy5pbmRleH1cbiAgICAgIGlzRHJhZ0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgID5cbiAgICAgIHsocHJvdmlkZWQpID0+IHtcbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8RHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgICAgIDxEcmFnZ2luZ0NvbnRhaW5lclxuICAgICAgICAgICAgICByZWY9e3Byb3ZpZGVkLmlubmVyUmVmfVxuICAgICAgICAgICAgICB7Li4ucHJvdmlkZWQuZHJhZ2dhYmxlUHJvcHN9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnSGFuZGxlUHJvcHN9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUYWdcbiAgICAgICAgICAgICAgICBvblJlbW92ZT17cHJvcHMub25SZW1vdmUgPyBoYW5kbGVSZW1vdmVDb2x1bW4gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgICBpc0RyYWdnYWJsZVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3Byb3BzLmNvbHVtbi5sYWJlbH1cbiAgICAgICAgICAgICAgPC9UYWc+XG4gICAgICAgICAgICA8L0RyYWdnaW5nQ29udGFpbmVyPlxuICAgICAgICAgIDwvRHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgKTtcbiAgICAgIH19XG4gICAgPC9EcmFnZ2FibGU+XG4gICk7XG59O1xuXG5EcmFnZ2FibGVUYWcuZGlzcGxheU5hbWUgPSAnRHJhZ2dhYmxlVGFnJztcblxuZXhwb3J0IGRlZmF1bHQgRHJhZ2dhYmxlVGFnO1xuIl19 */"));
311
- const DraggableTag = props => {
312
- const handleRemoveColumn = () => {
313
- var _props$onRemove;
314
- return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
315
- };
316
- return jsx(Draggable, {
317
- draggableId: props.column.key,
318
- index: props.index,
319
- isDragDisabled: props.isDisabled,
320
- children: provided => {
321
- return jsx(DraggableTagWrapper, {
322
- children: jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
323
- ref: provided.innerRef
324
- }, provided.draggableProps), provided.dragHandleProps), {}, {
325
- children: jsx(Tag, {
326
- onRemove: props.onRemove ? handleRemoveColumn : undefined,
327
- isDisabled: props.isDisabled,
328
- isDraggable: true,
329
- children: props.column.label
330
- })
331
- }))
332
- });
333
- }
334
- });
335
- };
336
- DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
337
- column: _pt.shape({
338
- key: _pt.string.isRequired,
339
- label: _pt.node.isRequired
340
- }).isRequired,
341
- index: _pt.number.isRequired,
342
- isDisabled: _pt.bool,
343
- onRemove: _pt.func
344
- } : {};
345
- DraggableTag.displayName = 'DraggableTag';
346
- var DraggableTag$1 = DraggableTag;
347
-
348
- const TagContainerEditable = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
349
- target: "e7rakq0"
350
- } : {
351
- target: "e7rakq0",
352
- label: "TagContainerEditable"
353
- })("background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";padding:", designTokens.spacing30, ";height:", designTokens.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
354
- var TagContainerEditable$1 = TagContainerEditable;
355
-
356
- var messages$2 = defineMessages({
357
- loadMoreAttributesHint: {
358
- id: 'UIKit.DataTableManager.ColumnManager.DroppablePanel.loadMoreAttributesHint',
359
- description: 'Indicate that the user can use the search input to load more attributes',
360
- defaultMessage: 'Load more attributes by using the search input above'
361
- }
362
- });
363
-
364
- const DroppablePanel = props => {
365
- return jsx(Droppable, {
366
- droppableId: props.droppableId,
367
- children: provided => {
368
- var _context;
369
- return jsxs(TagContainerEditable$1, {
370
- "data-testid": props.droppableId,
371
- ref: provided.innerRef,
372
- children: [props.columns.length === 0 ? jsx(Spacings.Inset, {
373
- scale: "s",
374
- children: jsx(Text.Detail, {
375
- tone: "secondary",
376
- children: props.noColumnsText
377
- })
378
- }) : jsxs(Fragment, {
379
- children: [_mapInstanceProperty(_context = props.columns).call(_context, (column, index) => {
380
- var _context2;
381
- return jsx(DraggableTag$1, {
382
- column: column,
383
- index: index,
384
- onRemove: props.onRemove ? () => {
385
- var _context3, _context4;
386
- return props.onRemove([..._sliceInstanceProperty(_context3 = props.columns).call(_context3, 0, index), ..._sliceInstanceProperty(_context4 = props.columns).call(_context4, index + 1)]);
387
- } : undefined,
388
- isDisabled: props.isDisabled
389
- }, _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index));
390
- }), props.isSearchable && jsx(Spacings.Inset, {
391
- scale: "xs",
392
- children: jsx(Text.Detail, {
393
- tone: "secondary",
394
- intlMessage: messages$2.loadMoreAttributesHint
395
- })
396
- })]
397
- }), provided.placeholder]
398
- });
399
- }
400
- });
401
- };
402
- DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
403
- droppableId: _pt.string.isRequired,
404
- noColumnsText: _pt.node.isRequired,
405
- columns: _pt.arrayOf(_pt.shape({
406
- key: _pt.string.isRequired,
407
- label: _pt.node.isRequired
408
- })).isRequired,
409
- isSearchable: _pt.bool,
410
- isDisabled: _pt.bool,
411
- onRemove: _pt.func
412
- } : {};
413
- DroppablePanel.displayName = 'DroppablePanel';
414
- var DroppablePanel$1 = DroppablePanel;
415
-
416
199
  var messages$1 = defineMessages({
417
- title: {
418
- id: 'UIKit.DataTableManager.ColumnManager.title',
419
- description: 'Title for the column manager component.',
420
- defaultMessage: 'Column Manager'
421
- },
422
- visibleColumns: {
423
- id: 'UIKit.DataTableManager.ColumnSelectorGroups.visible',
424
- description: 'Message for the visible columns section.',
425
- defaultMessage: 'Visible columns'
426
- },
427
- hiddenColumns: {
428
- id: 'UIKit.DataTableManager.ColumnManager.hiddenColumns',
429
- description: 'Message for the hidden columns section',
430
- defaultMessage: 'Hidden columns'
431
- },
432
- noSelectedColumnsToShow: {
433
- id: 'UIKit.DataTableManager.ColumnManager.noSelectedColumnsToShow',
434
- description: 'Label when there are no selected columns to show',
435
- defaultMessage: 'There are no selected columns to show.'
436
- },
437
- noHiddenColumnsToShow: {
438
- id: 'UIKit.DataTableManager.ColumnManager.noHiddenColumnsToShow',
439
- description: 'Label when there are no hidden columns to show',
440
- defaultMessage: 'There are no hidden columns to show.'
441
- },
442
200
  closeButtonLabel: {
443
- id: 'UIKit.DataTableManager.ColumnManager.closeButtonLabel',
444
- description: 'Label for density manager close button.',
201
+ id: 'UIKit.DataTableManager.CustomSettingsManager.closeButtonLabel',
202
+ description: 'Label for custom settings manager close button.',
445
203
  defaultMessage: 'Close'
446
204
  }
447
205
  });
448
206
 
449
- const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
450
- const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
451
-
452
- function ownKeys$2(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
453
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$2(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$2(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
454
- const noSearch = () => _Promise.resolve([]);
455
- // 'onChange' prop in AsyncSelectInput is required but not needed here
456
- const voidChangeHandler = () => undefined;
457
- const DroppableContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
458
- target: "en01od20"
459
- } : {
460
- target: "en01od20",
461
- label: "DroppableContainer"
462
- })("width:100%;position:relative;max-width:", designTokens.constraint10, ";cursor:", props => props.isDragging ? 'grabbing' : 'auto', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AA+D+D","file":"column-settings-manager.tsx","sourcesContent":["import {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\nexport type TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\nexport type TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"l\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"big\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  onChange={voidChangeHandler}\n                  loadOptions={noSearch}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nconst defaultProps: Pick<TColumnSettingsManagerProps, 'availableColumns'> = {\n  availableColumns: [],\n};\nColumnSettingsManager.defaultProps = defaultProps;\n\nexport default ColumnSettingsManager;\n"]} */"));
463
- const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
464
- setIsDragging(false);
465
- // Invalid drop destination, do nothing
466
- if (!dragResult.destination) return;
467
- if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {
468
- if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
469
- onUpdateColumns([..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)]);
470
- } else {
471
- // the destination is the selected columns panel
472
-
473
- // it's a swap when the source and the destination are the same
474
- const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
475
- const items = isSwap ?
476
- // remove the dragged item from its position if it is not coming from
477
- // the hidden section (it is a swap)
478
- [..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)] : selectedColumns;
479
- const columns = isSwap ? selectedColumns : availableColumns;
480
- const draggedColumn = _findInstanceProperty(columns).call(columns, col => col.key === dragResult.draggableId);
481
-
482
- // push the column in the new position if draggedColumn is found
483
- if (draggedColumn) {
484
- onUpdateColumns([..._sliceInstanceProperty(items).call(items, 0, dragResult.destination.index), draggedColumn, ..._sliceInstanceProperty(items).call(items, dragResult.destination.index)]);
485
- }
486
- }
487
- };
488
- const DropdownIndicator = () => jsx(Spacings.Inline, {
489
- alignItems: "center",
490
- children: jsx(SearchIcon, {
491
- size: "medium",
492
- color: "primary"
493
- })
494
- });
495
- DropdownIndicator.displayName = 'DropdownIndicator';
496
- const Nothing = () => null;
497
- const selectInputComponents = {
498
- Option: Nothing,
499
- Menu: Nothing,
500
- DropdownIndicator
501
- };
502
- const ColumnSettingsManager = props => {
503
- if (props.areHiddenColumnsSearchable) {
504
- process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
505
- }
506
- const intl = useIntl();
507
- const _useState = useState(false),
508
- _useState2 = _slicedToArray(_useState, 2),
509
- isDragging = _useState2[0],
510
- setIsDragging = _useState2[1];
511
- const searchHiddenColumns = props.searchHiddenColumns;
512
- const handleDragStart = () => {
513
- setIsDragging(true);
514
- };
515
- const hiddenColumns = useMemo(() => differenceWith(props.availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [props.availableColumns, props.selectedColumns]);
516
- const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
517
- const debouncedSearchHiddenColumns = useMemo(() => debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300), [searchHiddenColumns]);
518
- const handleInputChange = useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
519
- return jsx(SettingsContainer$1, {
520
- title: messages$1.title,
521
- closeButtonLabel: messages$1.closeButtonLabel,
522
- onClose: props.onClose,
523
- primaryButton: props.primaryButton,
524
- secondaryButton: props.secondaryButton,
525
- containerTheme: props.managerTheme,
526
- children: jsx(DragDropContext, {
527
- onDragEnd: handleDragEnd,
528
- onDragStart: handleDragStart,
529
- children: jsxs(Spacings.Inline, {
530
- scale: "l",
531
- children: [jsx(DroppableContainer, {
532
- isDragging: isDragging,
533
- "aria-labelledby": "hidden-columns",
534
- children: jsxs(Spacings.Stack, {
535
- scale: "m",
536
- children: [jsxs(Spacings.Inline, {
537
- scale: "s",
538
- alignItems: "center",
539
- children: [jsx(EyeCrossedIcon, {
540
- size: "big"
541
- }), jsx(FieldLabel, {
542
- id: "hidden-columns",
543
- title: intl.formatMessage(messages$1.hiddenColumns)
544
- })]
545
- }), props.areHiddenColumnsSearchable && jsx(AsyncSelectInput, _objectSpread$2(_objectSpread$2({}, props.searchHiddenColumnsPlaceholder ? {
546
- placeholder: props.searchHiddenColumnsPlaceholder
547
- } : undefined), {}, {
548
- onChange: voidChangeHandler,
549
- loadOptions: noSearch,
550
- onInputChange: handleInputChange,
551
- components: selectInputComponents
552
- })), jsx(DroppablePanel$1, {
553
- droppableId: HIDDEN_COLUMNS_PANEL,
554
- "data-testid": HIDDEN_COLUMNS_PANEL,
555
- noColumnsText: intl.formatMessage(messages$1.noHiddenColumnsToShow),
556
- columns: hiddenColumns,
557
- isSearchable: props.areHiddenColumnsSearchable
558
- })]
559
- })
560
- }), jsx(DroppableContainer, {
561
- isDragging: isDragging,
562
- "aria-labelledby": "visible-columns",
563
- children: jsxs(Spacings.Stack, {
564
- scale: "m",
565
- children: [jsxs(Spacings.Inline, {
566
- scale: "xs",
567
- alignItems: "center",
568
- children: [jsx(EyeIcon, {
569
- size: "medium"
570
- }), jsx(FieldLabel, {
571
- id: "visible-columns",
572
- title: intl.formatMessage(messages$1.visibleColumns)
573
- })]
574
- }), jsx(DroppablePanel$1, {
575
- droppableId: SELECTED_COLUMNS_PANEL,
576
- "data-testid": SELECTED_COLUMNS_PANEL,
577
- noColumnsText: intl.formatMessage(messages$1.noSelectedColumnsToShow),
578
- columns: props.selectedColumns,
579
- onRemove: props.onUpdateColumns
580
- })]
581
- })
582
- })]
583
- })
207
+ const CustomSettingsManager = props => {
208
+ return jsx(Fragment, {
209
+ children: jsx(SettingsContainer, {
210
+ customSettingsTitle: props.customPanelTitle,
211
+ closeButtonLabel: messages$1.closeButtonLabel,
212
+ onClose: props.onClose,
213
+ containerTheme: props.managerTheme,
214
+ children: props.children
584
215
  })
585
216
  });
586
217
  };
587
- ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
588
- availableColumns: _pt.arrayOf(_pt.shape({
589
- key: _pt.string.isRequired,
590
- label: _pt.node.isRequired
591
- })).isRequired,
592
- selectedColumns: _pt.arrayOf(_pt.shape({
593
- key: _pt.string.isRequired,
594
- label: _pt.node.isRequired
595
- })).isRequired,
596
- onUpdateColumns: _pt.func.isRequired,
597
- areHiddenColumnsSearchable: _pt.bool,
598
- searchHiddenColumns: _pt.func,
599
- searchHiddenColumnsPlaceholder: _pt.string,
218
+ CustomSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
600
219
  onClose: _pt.func.isRequired,
601
- primaryButton: _pt.element,
602
- secondaryButton: _pt.element,
603
- managerTheme: _pt.oneOf(['light', 'dark'])
220
+ managerTheme: _pt.oneOf(['light', 'dark']),
221
+ children: _pt.node.isRequired,
222
+ customPanelTitle: _pt.oneOfType([_pt.string, _pt.any]).isRequired
604
223
  } : {};
605
- ColumnSettingsManager.displayName = 'ColumnSettingsManager';
606
- const defaultProps = {
607
- availableColumns: []
608
- };
609
- ColumnSettingsManager.defaultProps = defaultProps;
610
- var ColumnSettingsManager$1 = ColumnSettingsManager;
224
+ CustomSettingsManager.displayName = 'CustomSettingsManager';
225
+ var CustomSettingsManager$1 = CustomSettingsManager;
611
226
 
612
227
  var messages = defineMessages({
613
228
  placeholder: {
@@ -628,7 +243,7 @@ var messages = defineMessages({
628
243
  });
629
244
 
630
245
  function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
631
- function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
246
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context4, _context5; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context4 = ownKeys$1(Object(t), !0)).call(_context4, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context5 = ownKeys$1(Object(t))).call(_context5, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
632
247
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
633
248
  const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
634
249
  target: "e3i1gnv0"
@@ -641,20 +256,33 @@ const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
641
256
  } : {
642
257
  name: "1ff36h2",
643
258
  styles: "flex-grow:1",
644
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAiCkC","file":"data-table-settings.tsx","sourcesContent":["import { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport { ColumnsIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\nimport DropdownMenu from '@commercetools-uikit/dropdown-menu';\nimport IconButton from '@commercetools-uikit/icon-button';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport { TColumnData, TDataTableSettingsProps } from '../types';\n\nexport type TSelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDropdownOption = {\n  value: string;\n  label: string;\n};\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n  const dropdownOptions: TDropdownOption[] = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale=\"xs\">\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <Tooltip\n            placement=\"left\"\n            title={intl.formatMessage(messages.placeholder)}\n          >\n            <DropdownMenu\n              triggerElement={\n                <IconButton\n                  icon={<ColumnsIcon />}\n                  label=\"Open table manager dropdown\"\n                />\n              }\n              menuHorizontalConstraint={'auto'}\n              menuPosition=\"right\"\n              menuType=\"list\"\n            >\n              {dropdownOptions?.map((option: TDropdownOption) => (\n                <DropdownMenu.ListMenuItem\n                  key={option?.label}\n                  onClick={() => {\n                    setOpenedPanelId(option?.value);\n                  }}\n                >\n                  {option?.label}\n                </DropdownMenu.ListMenuItem>\n              ))}\n            </DropdownMenu>\n          </Tooltip>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
259
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAsCkC","file":"data-table-settings.tsx","sourcesContent":["import { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport { ColumnsIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport { ColumnSettingsManager } from '../column-settings-manager';\nimport CustomSettingsManager from '../custom-settings-manager';\nimport messages from './messages';\nimport DropdownMenu from '@commercetools-uikit/dropdown-menu';\nimport IconButton from '@commercetools-uikit/icon-button';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  TColumnData,\n  TDataTableSettingsProps,\n  TCustomSettingsProps,\n} from '../types';\n\nexport type TSelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDropdownOption = {\n  value: string;\n  label: string;\n};\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areCustomColumnSettingsEnabled,\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  customSettings,\n  columnManagerLabel,\n  displaySettingsLabel,\n  formatMessage,\n}: {\n  areCustomColumnSettingsEnabled: boolean;\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  customSettings?: TCustomSettingsProps[];\n  columnManagerLabel?: string;\n  displaySettingsLabel?: string;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => {\n  return [\n    ...(areColumnSettingsEnabled\n      ? [\n          {\n            value: COLUMN_MANAGER,\n            label: columnManagerLabel\n              ? columnManagerLabel\n              : formatMessage(messages.columnManagerOption),\n          },\n        ]\n      : []),\n    ...(customSettings\n      ? Object.entries(customSettings).map(([key, customSetting]) => {\n          return customSetting.type === COLUMN_MANAGER &&\n            !areCustomColumnSettingsEnabled\n            ? undefined\n            : {\n                value: key,\n                label: customSetting.customPanelTitle,\n              };\n        })\n      : []),\n    ...(areDisplaySettingsEnabled\n      ? [\n          {\n            value: DISPLAY_SETTINGS,\n            label: displaySettingsLabel\n              ? displaySettingsLabel\n              : formatMessage(messages.displaySettingsOption),\n          },\n        ]\n      : []),\n  ].filter((option) => option !== undefined);\n};\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n\n  const areCustomColumnSettingsEnabled = Boolean(\n    props.customColumnManager &&\n      !props.customColumnManager?.disableCustomColumnManager\n  );\n\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions: TDropdownOption[] = getDropdownOptions({\n    areCustomColumnSettingsEnabled,\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    customSettings: props.customSettings,\n    columnManagerLabel: props.columnManager?.columnManagerLabel,\n    displaySettingsLabel: props.displaySettings?.displaySettingsLabel,\n    formatMessage: intl.formatMessage,\n  });\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale=\"xs\">\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <Tooltip\n            placement=\"left\"\n            title={intl.formatMessage(messages.placeholder)}\n          >\n            <DropdownMenu\n              triggerElement={\n                <IconButton\n                  icon={<ColumnsIcon />}\n                  label=\"Open table manager dropdown\"\n                />\n              }\n              menuHorizontalConstraint={'auto'}\n              menuPosition=\"right\"\n              menuType=\"list\"\n            >\n              {dropdownOptions?.map((option: TDropdownOption) => (\n                <DropdownMenu.ListMenuItem\n                  key={option?.label}\n                  onClick={() => {\n                    setOpenedPanelId(option?.value);\n                  }}\n                >\n                  {option?.label}\n                </DropdownMenu.ListMenuItem>\n              ))}\n            </DropdownMenu>\n          </Tooltip>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          title={props.displaySettings?.displaySettingsLabel}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          title={props.columnManager?.columnManagerLabel}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n      {props.customSettings &&\n        Object.entries(props.customSettings).map(([key, customSetting]) => {\n          if (!customSetting.key) {\n            throw new Error(\n              'ui-kit/DataTableManager: missing: `key` prop, `customSettings` must be a JSON in the format Record<string, Object>.'\n            );\n          }\n          const CustomComponent = customSetting.customComponent;\n          return (\n            key === openedPanelId && (\n              <div key={customSetting.key}>\n                {customSetting.type === COLUMN_MANAGER ? (\n                  CustomComponent && (\n                    <CustomComponent\n                      {...(customSetting || {})}\n                      additionalSettings={{\n                        ...customSetting,\n                        ...props.additionalSettings,\n                      }}\n                      onClose={handleSettingsPanelChange}\n                      managerTheme={props.managerTheme}\n                      selectedColumns={props.selectedColumns}\n                      availableColumns={props.customColumnManager ?? undefined}\n                      onUpdateColumns={(nextVisibleColumns, key) => {\n                        const keysOfVisibleColumns = nextVisibleColumns.map(\n                          (visibleColumn) => visibleColumn.key\n                        );\n                        props.onSettingsChange?.(\n                          UPDATE_ACTIONS.CUSTOM_COLUMNS_UPDATE,\n                          keysOfVisibleColumns,\n                          key\n                        );\n                      }}\n                    />\n                  )\n                ) : (\n                  <CustomSettingsManager\n                    {...(customSetting || {})}\n                    onClose={handleSettingsPanelChange}\n                    managerTheme={props.managerTheme}\n                  >\n                    {CustomComponent && (\n                      <CustomComponent\n                        updateCustomSettings={(settings) => {\n                          props.onSettingsChange?.(\n                            UPDATE_ACTIONS.CUSTOM_SETTINGS_UPDATE,\n                            settings\n                          );\n                        }}\n                        additionalSettings={{\n                          ...customSetting,\n                          ...props.additionalSettings,\n                        }}\n                      />\n                    )}\n                  </CustomSettingsManager>\n                )}\n              </div>\n            )\n          );\n        })}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
645
260
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
646
261
  });
647
262
  const getDropdownOptions = _ref => {
648
- let areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
263
+ var _context, _context2;
264
+ let areCustomColumnSettingsEnabled = _ref.areCustomColumnSettingsEnabled,
265
+ areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
649
266
  areDisplaySettingsEnabled = _ref.areDisplaySettingsEnabled,
267
+ customSettings = _ref.customSettings,
268
+ columnManagerLabel = _ref.columnManagerLabel,
269
+ displaySettingsLabel = _ref.displaySettingsLabel,
650
270
  formatMessage = _ref.formatMessage;
651
- return [...(areColumnSettingsEnabled ? [{
271
+ return _filterInstanceProperty(_context = [...(areColumnSettingsEnabled ? [{
652
272
  value: COLUMN_MANAGER,
653
- label: formatMessage(messages.columnManagerOption)
654
- }] : []), ...(areDisplaySettingsEnabled ? [{
273
+ label: columnManagerLabel ? columnManagerLabel : formatMessage(messages.columnManagerOption)
274
+ }] : []), ...(customSettings ? _mapInstanceProperty(_context2 = _Object$entries(customSettings)).call(_context2, _ref2 => {
275
+ let _ref3 = _slicedToArray(_ref2, 2),
276
+ key = _ref3[0],
277
+ customSetting = _ref3[1];
278
+ return customSetting.type === COLUMN_MANAGER && !areCustomColumnSettingsEnabled ? undefined : {
279
+ value: key,
280
+ label: customSetting.customPanelTitle
281
+ };
282
+ }) : []), ...(areDisplaySettingsEnabled ? [{
655
283
  value: DISPLAY_SETTINGS,
656
- label: formatMessage(messages.displaySettingsOption)
657
- }] : [])];
284
+ label: displaySettingsLabel ? displaySettingsLabel : formatMessage(messages.displaySettingsOption)
285
+ }] : [])]).call(_context, option => option !== undefined);
658
286
  };
659
287
  const getMappedColumns = function () {
660
288
  let columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
@@ -667,9 +295,10 @@ const getSelectedColumns = function (mappedColumns) {
667
295
  return _mapInstanceProperty(visibleColumnsKeys).call(visibleColumnsKeys, columnKey => mappedColumns[columnKey]);
668
296
  };
669
297
  const DataTableSettings = props => {
670
- var _props$columnManager$, _props$columnManager;
298
+ var _props$customColumnMa, _props$columnManager, _props$displaySetting, _props$displaySetting2, _props$columnManager2, _props$columnManager$, _props$columnManager3, _context3;
671
299
  const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
672
300
  const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
301
+ const areCustomColumnSettingsEnabled = Boolean(props.customColumnManager && !((_props$customColumnMa = props.customColumnManager) !== null && _props$customColumnMa !== void 0 && _props$customColumnMa.disableCustomColumnManager));
673
302
  process.env.NODE_ENV !== "production" ? warning(areDisplaySettingsEnabled || areColumnSettingsEnabled ? typeof props.onSettingsChange === 'function' : true, "ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.") : void 0;
674
303
  const intl = useIntl();
675
304
  const _useState = useState(null),
@@ -677,8 +306,12 @@ const DataTableSettings = props => {
677
306
  openedPanelId = _useState2[0],
678
307
  setOpenedPanelId = _useState2[1];
679
308
  const dropdownOptions = getDropdownOptions({
309
+ areCustomColumnSettingsEnabled,
680
310
  areDisplaySettingsEnabled,
681
311
  areColumnSettingsEnabled,
312
+ customSettings: props.customSettings,
313
+ columnManagerLabel: (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.columnManagerLabel,
314
+ displaySettingsLabel: (_props$displaySetting = props.displaySettings) === null || _props$displaySetting === void 0 ? void 0 : _props$displaySetting.displaySettingsLabel,
682
315
  formatMessage: intl.formatMessage
683
316
  });
684
317
  const mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
@@ -711,6 +344,7 @@ const DataTableSettings = props => {
711
344
  })
712
345
  })]
713
346
  }), openedPanelId === DISPLAY_SETTINGS && jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
347
+ title: (_props$displaySetting2 = props.displaySettings) === null || _props$displaySetting2 === void 0 ? void 0 : _props$displaySetting2.displaySettingsLabel,
714
348
  onClose: handleSettingsPanelChange,
715
349
  onDensityDisplayChange: event => {
716
350
  var _props$onSettingsChan;
@@ -721,8 +355,9 @@ const DataTableSettings = props => {
721
355
  (_props$onSettingsChan2 = props.onSettingsChange) === null || _props$onSettingsChan2 === void 0 || _props$onSettingsChan2.call(props, UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
722
356
  },
723
357
  managerTheme: props.managerTheme
724
- })), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager$1, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
725
- availableColumns: (_props$columnManager$ = (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
358
+ })), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
359
+ title: (_props$columnManager2 = props.columnManager) === null || _props$columnManager2 === void 0 ? void 0 : _props$columnManager2.columnManagerLabel,
360
+ availableColumns: (_props$columnManager$ = (_props$columnManager3 = props.columnManager) === null || _props$columnManager3 === void 0 ? void 0 : _props$columnManager3.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
726
361
  selectedColumns: selectedColumns,
727
362
  onClose: handleSettingsPanelChange,
728
363
  onUpdateColumns: nextVisibleColumns => {
@@ -731,7 +366,40 @@ const DataTableSettings = props => {
731
366
  (_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 || _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
732
367
  },
733
368
  managerTheme: props.managerTheme
734
- }))]
369
+ })), props.customSettings && _mapInstanceProperty(_context3 = _Object$entries(props.customSettings)).call(_context3, _ref4 => {
370
+ var _props$customColumnMa2;
371
+ let _ref5 = _slicedToArray(_ref4, 2),
372
+ key = _ref5[0],
373
+ customSetting = _ref5[1];
374
+ if (!customSetting.key) {
375
+ throw new Error('ui-kit/DataTableManager: missing: `key` prop, `customSettings` must be a JSON in the format Record<string, Object>.');
376
+ }
377
+ const CustomComponent = customSetting.customComponent;
378
+ return key === openedPanelId && jsx("div", {
379
+ children: customSetting.type === COLUMN_MANAGER ? CustomComponent && jsx(CustomComponent, _objectSpread$1(_objectSpread$1({}, customSetting || {}), {}, {
380
+ additionalSettings: _objectSpread$1(_objectSpread$1({}, customSetting), props.additionalSettings),
381
+ onClose: handleSettingsPanelChange,
382
+ managerTheme: props.managerTheme,
383
+ selectedColumns: props.selectedColumns,
384
+ availableColumns: (_props$customColumnMa2 = props.customColumnManager) !== null && _props$customColumnMa2 !== void 0 ? _props$customColumnMa2 : undefined,
385
+ onUpdateColumns: (nextVisibleColumns, key) => {
386
+ var _props$onSettingsChan4;
387
+ const keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, visibleColumn => visibleColumn.key);
388
+ (_props$onSettingsChan4 = props.onSettingsChange) === null || _props$onSettingsChan4 === void 0 || _props$onSettingsChan4.call(props, UPDATE_ACTIONS.CUSTOM_COLUMNS_UPDATE, keysOfVisibleColumns, key);
389
+ }
390
+ })) : jsx(CustomSettingsManager$1, _objectSpread$1(_objectSpread$1({}, customSetting || {}), {}, {
391
+ onClose: handleSettingsPanelChange,
392
+ managerTheme: props.managerTheme,
393
+ children: CustomComponent && jsx(CustomComponent, {
394
+ updateCustomSettings: settings => {
395
+ var _props$onSettingsChan5;
396
+ (_props$onSettingsChan5 = props.onSettingsChange) === null || _props$onSettingsChan5 === void 0 || _props$onSettingsChan5.call(props, UPDATE_ACTIONS.CUSTOM_SETTINGS_UPDATE, settings);
397
+ },
398
+ additionalSettings: _objectSpread$1(_objectSpread$1({}, customSetting), props.additionalSettings)
399
+ })
400
+ }))
401
+ }, customSetting.key);
402
+ })]
735
403
  });
736
404
  };
737
405
  DataTableSettings.displayName = 'DataTableSettings';
@@ -746,6 +414,10 @@ const DataTableManager = props => {
746
414
  const topBar = props.topBar || dataTableManagerContext.topBar;
747
415
  const onSettingsChange = props.onSettingsChange || dataTableManagerContext.onSettingsChange;
748
416
  const columnManager = props.columnManager || dataTableManagerContext.columnManager;
417
+ const customSettings = props.customSettings || dataTableManagerContext.customSettings;
418
+ const selectedColumns = props.selectedColumns || dataTableManagerContext.selectedColumns;
419
+ const customColumnManager = props.customColumnManager || dataTableManagerContext.customColumnManager;
420
+ const customColumns = props.customColumns || dataTableManagerContext.customColumns;
749
421
  const areDisplaySettingsEnabled = Boolean(displaySettings && !displaySettings.disableDisplaySettings);
750
422
  const isWrappingText = areDisplaySettingsEnabled && displaySettings.isWrappingText;
751
423
  if (!dataTableColumns) {
@@ -754,15 +426,32 @@ const DataTableManager = props => {
754
426
  const columns = useMemo(() => _mapInstanceProperty(dataTableColumns).call(dataTableColumns, column => _objectSpread(_objectSpread({}, column), {}, {
755
427
  isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
756
428
  })), [dataTableColumns, areDisplaySettingsEnabled, isWrappingText]);
429
+ const _useState = useState({
430
+ key: ''
431
+ }),
432
+ _useState2 = _slicedToArray(_useState, 2),
433
+ additionalSettings = _useState2[0],
434
+ setAdditionalSettings = _useState2[1];
435
+ const additionalCustomSetting = dataTableManagerContext.additionalSettings || additionalSettings;
436
+ const updateSettings = additionalCustomSettings => {
437
+ setAdditionalSettings(additionalCustomSettings);
438
+ };
439
+ const updateCustomSettings = dataTableManagerContext.updateCustomSettings || updateSettings;
757
440
  return jsxs(Spacings.Stack, {
758
441
  children: [jsx(DataTableSettings$1, {
759
442
  topBar: topBar,
760
443
  onSettingsChange: onSettingsChange,
761
444
  columnManager: columnManager,
762
445
  displaySettings: displaySettings,
763
- managerTheme: "light"
446
+ customSettings: customSettings,
447
+ managerTheme: "light",
448
+ additionalSettings: additionalCustomSetting,
449
+ updateCustomSettings: settings => updateCustomSettings(settings),
450
+ selectedColumns: selectedColumns !== null && selectedColumns !== void 0 ? selectedColumns : [],
451
+ customColumnManager: customColumnManager !== null && customColumnManager !== void 0 ? customColumnManager : undefined
764
452
  }), props.children ? /*#__PURE__*/cloneElement(props.children, {
765
453
  columns,
454
+ customColumns,
766
455
  isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
767
456
  }) : null]
768
457
  });
@@ -771,6 +460,6 @@ DataTableManager.displayName = 'DataTableManager';
771
460
  var DataTableManager$1 = DataTableManager;
772
461
 
773
462
  // NOTE: This string will be replaced on build time with the package version.
774
- var version = "19.9.0";
463
+ var version = "19.10.0";
775
464
 
776
465
  export { UPDATE_ACTIONS, DataTableManager$1 as default, version };