@commercetools-uikit/data-table-manager 13.0.3 → 13.0.4

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 (29) hide show
  1. package/dist/commercetools-uikit-data-table-manager.cjs.d.ts +2 -0
  2. package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +169 -347
  3. package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +67 -38
  4. package/dist/commercetools-uikit-data-table-manager.esm.js +165 -344
  5. package/dist/declarations/src/column-settings-manager/column-settings-manager.d.ts +25 -0
  6. package/dist/declarations/src/column-settings-manager/constants.d.ts +2 -0
  7. package/dist/declarations/src/column-settings-manager/index.d.ts +1 -0
  8. package/dist/declarations/src/column-settings-manager/messages.d.ts +33 -0
  9. package/dist/declarations/src/constants.d.ts +7 -0
  10. package/dist/declarations/src/data-table-manager.d.ts +32 -0
  11. package/dist/declarations/src/data-table-settings/data-table-settings.d.ts +46 -0
  12. package/dist/declarations/src/data-table-settings/index.d.ts +1 -0
  13. package/dist/declarations/src/data-table-settings/messages.d.ts +18 -0
  14. package/dist/declarations/src/display-settings-manager/constants.d.ts +4 -0
  15. package/dist/declarations/src/display-settings-manager/display-settings-manager.d.ts +17 -0
  16. package/dist/declarations/src/display-settings-manager/index.d.ts +2 -0
  17. package/dist/declarations/src/display-settings-manager/messages.d.ts +43 -0
  18. package/dist/declarations/src/draggable-tag/draggable-tag.d.ts +16 -0
  19. package/dist/declarations/src/draggable-tag/draggable-tag.styles.d.ts +6 -0
  20. package/dist/declarations/src/draggable-tag/index.d.ts +1 -0
  21. package/dist/declarations/src/droppable-panel/droppable-panel.d.ts +18 -0
  22. package/dist/declarations/src/droppable-panel/index.d.ts +1 -0
  23. package/dist/declarations/src/droppable-panel/messages.d.ts +8 -0
  24. package/dist/declarations/src/droppable-panel/tag-container-editable.d.ts +6 -0
  25. package/dist/declarations/src/index.d.ts +4 -0
  26. package/dist/declarations/src/settings-container/index.d.ts +1 -0
  27. package/dist/declarations/src/settings-container/settings-container.d.ts +21 -0
  28. package/dist/declarations/src/version.d.ts +2 -0
  29. package/package.json +15 -14
@@ -2,6 +2,9 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
6
+ var _pt = require('prop-types');
7
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
5
8
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
6
9
  var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
7
10
  var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
@@ -10,9 +13,6 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
10
13
  var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
11
14
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
12
15
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
13
- var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
- var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
15
- var PropTypes = require('prop-types');
16
16
  var react = require('react');
17
17
  var Spacings = require('@commercetools-uikit/spacings');
18
18
  var jsxRuntime = require('@emotion/react/jsx-runtime');
@@ -21,6 +21,7 @@ var _toConsumableArray = require('@babel/runtime-corejs3/helpers/toConsumableArr
21
21
  var _styled = require('@emotion/styled/base');
22
22
  var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
23
23
  var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
24
+ var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
24
25
  var utils = require('@commercetools-uikit/utils');
25
26
  var reactIntl = require('react-intl');
26
27
  var AccessibleHiden = require('@commercetools-uikit/accessible-hidden');
@@ -34,9 +35,9 @@ var AccessibleButton = require('@commercetools-uikit/accessible-button');
34
35
  var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
35
36
  var Card = require('@commercetools-uikit/card');
36
37
  var Text = require('@commercetools-uikit/text');
38
+ var _Promise = require('@babel/runtime-corejs3/core-js-stable/promise');
37
39
  var _sliceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/slice');
38
40
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
39
- var requiredIf = require('react-required-if');
40
41
  var reactBeautifulDnd = require('react-beautiful-dnd');
41
42
  var debounce = require('debounce-promise');
42
43
  var differenceWith = require('lodash/differenceWith');
@@ -46,6 +47,8 @@ var hooks = require('@commercetools-uikit/hooks');
46
47
 
47
48
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
48
49
 
50
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
51
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
49
52
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
50
53
  var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
51
54
  var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
@@ -54,12 +57,11 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
54
57
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
55
58
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
56
59
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
57
- var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
58
- var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
59
60
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
60
61
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
61
62
  var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
62
63
  var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
64
+ var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
63
65
  var AccessibleHiden__default = /*#__PURE__*/_interopDefault(AccessibleHiden);
64
66
  var SelectInput__default = /*#__PURE__*/_interopDefault(SelectInput);
65
67
  var FieldLabel__default = /*#__PURE__*/_interopDefault(FieldLabel);
@@ -69,9 +71,9 @@ var AccessibleButton__default = /*#__PURE__*/_interopDefault(AccessibleButton);
69
71
  var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
70
72
  var Card__default = /*#__PURE__*/_interopDefault(Card);
71
73
  var Text__default = /*#__PURE__*/_interopDefault(Text);
74
+ var _Promise__default = /*#__PURE__*/_interopDefault(_Promise);
72
75
  var _sliceInstanceProperty__default = /*#__PURE__*/_interopDefault(_sliceInstanceProperty);
73
76
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
74
- var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
75
77
  var debounce__default = /*#__PURE__*/_interopDefault(debounce);
76
78
  var differenceWith__default = /*#__PURE__*/_interopDefault(differenceWith);
77
79
  var AsyncSelectInput__default = /*#__PURE__*/_interopDefault(AsyncSelectInput);
@@ -88,9 +90,9 @@ var DISPLAY_SETTINGS = 'displaySettings';
88
90
  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)."; }
89
91
 
90
92
  var HeaderContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
91
- target: "e16v1mgb0"
93
+ target: "e6ezr100"
92
94
  } : {
93
- target: "e16v1mgb0",
95
+ target: "e6ezr100",
94
96
  label: "HeaderContainer"
95
97
  })(process.env.NODE_ENV === "production" ? {
96
98
  name: "1bhm8h2",
@@ -98,7 +100,7 @@ var HeaderContainer = _styled__default["default"]("div", process.env.NODE_ENV ==
98
100
  } : {
99
101
  name: "1bhm8h2",
100
102
  styles: "display:flex;flex:1;justify-content:space-between",
101
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0MiLCJmaWxlIjoic2V0dGluZ3MtY29udGFpbmVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cImZsYXRcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgzXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICA8QWNjZXNzaWJsZUJ1dHRvblxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9e3Byb3BzLm9uQ2xvc2V9XG4gICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxDbG9zZUljb24gc2l6ZT1cIm1lZGl1bVwiIC8+XG4gICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgIDwvSGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgc3R5bGU9e2NvbnRhaW5lclN0eWxlc30+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLkluc2V0PlxuICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICB7cHJvcHMuc2Vjb25kYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblNldHRpbmdzQ29udGFpbmVyLnByb3BUeXBlcyA9IHtcbiAgdGl0bGU6IFByb3BUeXBlcy5zaGFwZSh7XG4gICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBkZWZhdWx0TWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICB9KS5pc1JlcXVpcmVkLFxuICBjbG9zZUJ1dHRvbkxhYmVsOiBQcm9wVHlwZXMuc2hhcGUoe1xuICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgZGVmYXVsdE1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgfSkuaXNSZXF1aXJlZCxcbiAgb25DbG9zZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgcHJpbWFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIHNlY29uZGFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICBjb250YWluZXJUaGVtZTogUHJvcFR5cGVzLm9uZU9mKFsnbGlnaHQnLCAnZGFyayddKSxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
103
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbnR5cGUgVFNldHRpbmdzQ29udGFpbmVyUHJvcHMgPSB7XG4gIHRpdGxlOiBNZXNzYWdlRGVzY3JpcHRvciAmIHtcbiAgICB2YWx1ZXM/OiBSZWNvcmQ8c3RyaW5nLCBSZWFjdC5SZWFjdE5vZGU+O1xuICB9O1xuICBjbG9zZUJ1dHRvbkxhYmVsOiBNZXNzYWdlRGVzY3JpcHRvciAmIHtcbiAgICB2YWx1ZXM/OiBSZWNvcmQ8c3RyaW5nLCBSZWFjdC5SZWFjdE5vZGU+O1xuICB9O1xuICBvbkNsb3NlOiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICBwcmltYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBzZWNvbmRhcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGNvbnRhaW5lclRoZW1lPzogJ2xpZ2h0JyB8ICdkYXJrJztcbn07XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzOiBUU2V0dGluZ3NDb250YWluZXJQcm9wcykgPT4ge1xuICBjb25zdCBpbnRsID0gdXNlSW50bCgpO1xuXG4gIHJldHVybiAoXG4gICAgPENvbGxhcHNpYmxlTW90aW9uIGlzRGVmYXVsdENsb3NlZD17ZmFsc2V9PlxuICAgICAgeyh7IHJlZ2lzdGVyQ29udGVudE5vZGUsIGNvbnRhaW5lclN0eWxlcyB9KSA9PiAoXG4gICAgICAgIDxDYXJkIHR5cGU9XCJmbGF0XCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4c1wiPlxuICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoM1wiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgPEFjY2Vzc2libGVCdXR0b25cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgIGxhYmVsPXtpbnRsLmZvcm1hdE1lc3NhZ2UocHJvcHMuY2xvc2VCdXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICA8L0FjY2Vzc2libGVCdXR0b24+XG4gICAgICAgICAgICA8L0hlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbnNldCBzY2FsZT1cInNcIj5cbiAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUganVzdGlmeUNvbnRlbnQ9XCJmbGV4LWVuZFwiPlxuICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICA8L0NhcmQ+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gICk7XG59O1xuXG5TZXR0aW5nc0NvbnRhaW5lci5kaXNwbGF5TmFtZSA9ICdTZXR0aW5nc0NvbnRhaW5lcic7XG5cbmNvbnN0IGRlZmF1bHRQcm9wczogUGljazxUU2V0dGluZ3NDb250YWluZXJQcm9wcywgJ2NvbnRhaW5lclRoZW1lJz4gPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuU2V0dGluZ3NDb250YWluZXIuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
102
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
103
105
  });
104
106
 
@@ -147,25 +149,24 @@ var SettingsContainer = function SettingsContainer(props) {
147
149
  });
148
150
  };
149
151
 
150
- SettingsContainer.displayName = 'SettingsContainer';
151
152
  SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
152
- title: PropTypes__default["default"].shape({
153
- id: PropTypes__default["default"].string.isRequired,
154
- defaultMessage: PropTypes__default["default"].string.isRequired
155
- }).isRequired,
156
- closeButtonLabel: PropTypes__default["default"].shape({
157
- id: PropTypes__default["default"].string.isRequired,
158
- defaultMessage: PropTypes__default["default"].string.isRequired
159
- }).isRequired,
160
- onClose: PropTypes__default["default"].func.isRequired,
161
- primaryButton: PropTypes__default["default"].element,
162
- secondaryButton: PropTypes__default["default"].element,
163
- children: PropTypes__default["default"].node.isRequired,
164
- containerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
153
+ title: _pt__default["default"].oneOfType([_pt__default["default"].any, _pt__default["default"].shape({
154
+ values: _pt__default["default"].objectOf(_pt__default["default"].node)
155
+ })]).isRequired,
156
+ closeButtonLabel: _pt__default["default"].oneOfType([_pt__default["default"].any, _pt__default["default"].shape({
157
+ values: _pt__default["default"].objectOf(_pt__default["default"].node)
158
+ })]).isRequired,
159
+ onClose: _pt__default["default"].func.isRequired,
160
+ primaryButton: _pt__default["default"].element,
161
+ secondaryButton: _pt__default["default"].element,
162
+ children: _pt__default["default"].node.isRequired,
163
+ containerTheme: _pt__default["default"].oneOf(['light', 'dark'])
165
164
  } : {};
166
- SettingsContainer.defaultProps = {
165
+ SettingsContainer.displayName = 'SettingsContainer';
166
+ var defaultProps$2 = {
167
167
  containerTheme: 'dark'
168
168
  };
169
+ SettingsContainer.defaultProps = defaultProps$2;
169
170
  var SettingsContainer$1 = SettingsContainer;
170
171
 
171
172
  var messages$3 = reactIntl.defineMessages({
@@ -289,29 +290,30 @@ var DensityManager = function DensityManager(props) {
289
290
  });
290
291
  };
291
292
 
293
+ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
294
+ isCondensed: _pt__default["default"].bool,
295
+ isWrappingText: _pt__default["default"].bool,
296
+ primaryButton: _pt__default["default"].element,
297
+ secondaryButton: _pt__default["default"].element,
298
+ onDensityDisplayChange: _pt__default["default"].func.isRequired,
299
+ onTextWrappingChange: _pt__default["default"].func.isRequired,
300
+ onClose: _pt__default["default"].func.isRequired,
301
+ managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
302
+ } : {};
292
303
  DensityManager.displayName = 'DensityManager';
293
- DensityManager.defaultProps = {
304
+ var defaultProps$1 = {
294
305
  isCondensed: false,
295
306
  isWrappingText: false
296
307
  };
297
- DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
298
- isCondensed: PropTypes__default["default"].bool,
299
- isWrappingText: PropTypes__default["default"].bool,
300
- primaryButton: PropTypes__default["default"].element,
301
- secondaryButton: PropTypes__default["default"].element,
302
- onDensityDisplayChange: PropTypes__default["default"].func.isRequired,
303
- onTextWrappingChange: PropTypes__default["default"].func.isRequired,
304
- onClose: PropTypes__default["default"].func.isRequired,
305
- managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
306
- } : {};
308
+ DensityManager.defaultProps = defaultProps$1;
307
309
  var DisplaySettingsManager = DensityManager;
308
310
 
309
311
  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)."; }
310
312
 
311
313
  var DraggingSmall = _styled__default["default"]("small", process.env.NODE_ENV === "production" ? {
312
- target: "ed3a5rx1"
314
+ target: "e1mp438g1"
313
315
  } : {
314
- target: "ed3a5rx1",
316
+ target: "e1mp438g1",
315
317
  label: "DraggingSmall"
316
318
  })(process.env.NODE_ENV === "production" ? {
317
319
  name: "1fhyj3b",
@@ -319,16 +321,16 @@ var DraggingSmall = _styled__default["default"]("small", process.env.NODE_ENV ==
319
321
  } : {
320
322
  name: "1fhyj3b",
321
323
  styles: "&:hover{cursor:grab;}",
322
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVrQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */",
324
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFa0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */",
323
325
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
324
326
  });
325
327
 
326
328
  var DraggingContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
327
- target: "ed3a5rx0"
329
+ target: "e1mp438g0"
328
330
  } : {
329
- target: "ed3a5rx0",
331
+ target: "e1mp438g0",
330
332
  label: "DraggingContainer"
331
- })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFvQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */"));
333
+ })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRb0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */"));
332
334
 
333
335
  var DraggingContainer$1 = DraggingContainer;
334
336
 
@@ -338,7 +340,9 @@ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) {
338
340
 
339
341
  var DraggableTag = function DraggableTag(props) {
340
342
  var handleRemoveColumn = function handleRemoveColumn() {
341
- return props.onRemove(props.index);
343
+ var _props$onRemove;
344
+
345
+ return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
342
346
  };
343
347
 
344
348
  return jsxRuntime.jsx(reactBeautifulDnd.Draggable, {
@@ -346,9 +350,9 @@ var DraggableTag = function DraggableTag(props) {
346
350
  index: props.index,
347
351
  isDragDisabled: props.isDisabled,
348
352
  children: function children(provided) {
349
- return jsxRuntime.jsxs(Spacings__default["default"].Inset, {
353
+ return jsxRuntime.jsx(Spacings__default["default"].Inset, {
350
354
  scale: "xs",
351
- children: [jsxRuntime.jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
355
+ children: jsxRuntime.jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
352
356
  ref: provided.innerRef
353
357
  }, provided.draggableProps), provided.dragHandleProps), {}, {
354
358
  children: jsxRuntime.jsx(Tag__default["default"], {
@@ -362,30 +366,30 @@ var DraggableTag = function DraggableTag(props) {
362
366
  }), props.column.label]
363
367
  })
364
368
  })
365
- })), provided.placeholder]
369
+ }))
366
370
  });
367
371
  }
368
372
  });
369
373
  };
370
374
 
371
- DraggableTag.displayName = 'DraggableTag';
372
375
  DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
373
- column: PropTypes__default["default"].shape({
374
- key: PropTypes__default["default"].string.isRequired,
375
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
376
+ column: _pt__default["default"].shape({
377
+ key: _pt__default["default"].string.isRequired,
378
+ label: _pt__default["default"].node.isRequired
376
379
  }).isRequired,
377
- index: PropTypes__default["default"].number.isRequired,
378
- onRemove: PropTypes__default["default"].func,
379
- isDisabled: PropTypes__default["default"].bool
380
+ index: _pt__default["default"].number.isRequired,
381
+ isDisabled: _pt__default["default"].bool,
382
+ onRemove: _pt__default["default"].func
380
383
  } : {};
384
+ DraggableTag.displayName = 'DraggableTag';
381
385
  var DraggableTag$1 = DraggableTag;
382
386
 
383
387
  var TagContainerEditable = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
384
- target: "ecy2q1d0"
388
+ target: "e7rakq0"
385
389
  } : {
386
- target: "ecy2q1d0",
390
+ target: "e7rakq0",
387
391
  label: "TagContainerEditable"
388
- })("background-color:", designSystem.customProperties.backgroundColorForInput, ";border:", designSystem.customProperties.borderRadius1, " solid ", designSystem.customProperties.colorNeutral60, ";border-radius:", designSystem.customProperties.borderRadius6, ";padding:", designSystem.customProperties.spacingS, ";height:", designSystem.customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR3VDIiwiZmlsZSI6InRhZy1jb250YWluZXItZWRpdGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgVGFnQ29udGFpbmVyRWRpdGFibGUgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXR9O1xuICBib3JkZXI6ICR7dmFycy5ib3JkZXJSYWRpdXMxfSBzb2xpZCAke3ZhcnMuY29sb3JOZXV0cmFsNjB9O1xuICBib3JkZXItcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzNn07XG4gIHBhZGRpbmc6ICR7dmFycy5zcGFjaW5nU307XG4gIGhlaWdodDogJHt2YXJzLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
392
+ })("background-color:", designSystem.customProperties.backgroundColorForInput, ";border:", designSystem.customProperties.borderRadius1, " solid ", designSystem.customProperties.colorNeutral60, ";border-radius:", designSystem.customProperties.borderRadius6, ";padding:", designSystem.customProperties.spacingS, ";height:", designSystem.customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7dmFycy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dH07XG4gIGJvcmRlcjogJHt2YXJzLmJvcmRlclJhZGl1czF9IHNvbGlkICR7dmFycy5jb2xvck5ldXRyYWw2MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXM2fTtcbiAgcGFkZGluZzogJHt2YXJzLnNwYWNpbmdTfTtcbiAgaGVpZ2h0OiAke3ZhcnMuY29uc3RyYWludDd9O1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IFRhZ0NvbnRhaW5lckVkaXRhYmxlO1xuIl19 */"));
389
393
 
390
394
  var TagContainerEditable$1 = TagContainerEditable;
391
395
 
@@ -439,18 +443,18 @@ var DroppablePanel = function DroppablePanel(props) {
439
443
  });
440
444
  };
441
445
 
442
- DroppablePanel.displayName = 'DroppablePanel';
443
446
  DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
444
- droppableId: PropTypes__default["default"].string.isRequired,
445
- noColumnsText: PropTypes__default["default"].node.isRequired,
446
- columns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
447
- key: PropTypes__default["default"].string.isRequired,
448
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
449
- })),
450
- isSearchable: PropTypes__default["default"].bool,
451
- isDisabled: PropTypes__default["default"].bool,
452
- onRemove: PropTypes__default["default"].func
447
+ droppableId: _pt__default["default"].string.isRequired,
448
+ noColumnsText: _pt__default["default"].node.isRequired,
449
+ columns: _pt__default["default"].arrayOf(_pt__default["default"].shape({
450
+ key: _pt__default["default"].string.isRequired,
451
+ label: _pt__default["default"].node.isRequired
452
+ })).isRequired,
453
+ isSearchable: _pt__default["default"].bool,
454
+ isDisabled: _pt__default["default"].bool,
455
+ onRemove: _pt__default["default"].func
453
456
  } : {};
457
+ DroppablePanel.displayName = 'DroppablePanel';
454
458
  var DroppablePanel$1 = DroppablePanel;
455
459
 
456
460
  var messages$1 = reactIntl.defineMessages({
@@ -493,14 +497,18 @@ function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys__default["d
493
497
 
494
498
  function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context4 = ownKeys$2(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context5 = ownKeys$2(Object(source))).call(_context5, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
495
499
 
500
+ var noSearch = function noSearch() {
501
+ return _Promise__default["default"].resolve();
502
+ };
503
+
496
504
  var DroppableContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
497
- target: "e6ge22w0"
505
+ target: "en01od20"
498
506
  } : {
499
- target: "e6ge22w0",
507
+ target: "en01od20",
500
508
  label: "DroppableContainer"
501
509
  })("width:100%;position:relative;max-width:", designSystem.customProperties.constraint10, ";cursor:", function (props) {
502
510
  return props.isDragging ? 'grabbing' : 'auto';
503
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.js"],"names":[],"mappings":"AAsBqC","file":"column-settings-manager.js","sourcesContent":["import { useMemo, useCallback, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } 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 DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\nconst DroppableContainer = styled.div`\n  width: 100%;\n  position: relative;\n  max-width: ${vars.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult,\n  onUpdateColumns,\n  selectedColumns,\n  availableColumns,\n  setIsDragging\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\n    onUpdateColumns([\n      ...items.slice(0, dragResult.destination.index),\n      draggedColumn,\n      ...items.slice(dragResult.destination.index),\n    ]);\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon scale=\"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) => {\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(\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 handleInputChange = useCallback(\n    (input) =>\n      // loadOptions is not invoked when input is empty\n      !input.length && searchHiddenColumns(input),\n    [searchHiddenColumns]\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=\"m\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"medium\" />\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                  cacheOptions={false}\n                  onChange={() => {\n                    // to avoid prop-types error\n                    // as `onChange` is a required prop in\n                    // `AsyncSelectInput`\n                  }}\n                  // loadOptions is used instead of onInputChange\n                  // because the loading indicator is displayed\n                  // only when loadOptions is invoked\n                  loadOptions={debounce(searchHiddenColumns, 300)}\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>\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\nColumnSettingsManager.propTypes = {\n  availableColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  selectedColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  onUpdateColumns: PropTypes.func.isRequired,\n\n  areHiddenColumnsSearchable: PropTypes.bool,\n  searchHiddenColumns: requiredIf(\n    PropTypes.func,\n    (props) => props.areHiddenColumnsSearchable\n  ),\n  searchHiddenColumnsPlaceholder: PropTypes.string,\n\n  onClose: PropTypes.func,\n  primaryButton: PropTypes.element,\n  secondaryButton: PropTypes.element,\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nColumnSettingsManager.defaultProps = {\n  availableColumns: [],\n};\n\nexport default ColumnSettingsManager;\n"]} */"));
511
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AA6D+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 { customProperties as vars } 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\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<unknown>;\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: ${vars.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 handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) =>\n      // loadOptions is not invoked when input is empty\n      !inputValue.length && searchHiddenColumns?.(inputValue),\n    [searchHiddenColumns]\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=\"m\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"medium\" />\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                  cacheOptions={false}\n                  onChange={() => {\n                    // to avoid prop-types error\n                    // as `onChange` is a required prop in\n                    // `AsyncSelectInput`\n                  }}\n                  // loadOptions is used instead of onInputChange\n                  // because the loading indicator is displayed\n                  // only when loadOptions is invoked\n                  loadOptions={debounce(searchHiddenColumns ?? noSearch, 300)}\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>\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"]} */"));
504
512
 
505
513
  var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) {
506
514
  setIsDragging(false); // Invalid drop destination, do nothing
@@ -513,7 +521,7 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
513
521
  if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
514
522
  onUpdateColumns(_concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, 0, dragResult.source.index)), _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, dragResult.source.index + 1))));
515
523
  } else {
516
- var _context2, _context3;
524
+ var _context2;
517
525
 
518
526
  // the destination is the selected columns panel
519
527
  // it's a swap when the source and the destination are the same
@@ -525,10 +533,14 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
525
533
 
526
534
  var draggedColumn = _findInstanceProperty__default["default"](columns).call(columns, function (col) {
527
535
  return col.key === dragResult.draggableId;
528
- }); // push the column in the new position
536
+ }); // push the column in the new position if draggedColumn is found
537
+
529
538
 
539
+ if (draggedColumn) {
540
+ var _context3;
530
541
 
531
- onUpdateColumns(_concatInstanceProperty__default["default"](_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty__default["default"](items).call(items, 0, dragResult.destination.index)), [draggedColumn], _toConsumableArray(_sliceInstanceProperty__default["default"](items).call(items, dragResult.destination.index))));
542
+ onUpdateColumns(_concatInstanceProperty__default["default"](_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty__default["default"](items).call(items, 0, dragResult.destination.index)), [draggedColumn], _toConsumableArray(_sliceInstanceProperty__default["default"](items).call(items, dragResult.destination.index))));
543
+ }
532
544
  }
533
545
  };
534
546
 
@@ -536,7 +548,7 @@ var DropdownIndicator = function DropdownIndicator() {
536
548
  return jsxRuntime.jsx(Spacings__default["default"].Inline, {
537
549
  alignItems: "center",
538
550
  children: jsxRuntime.jsx(icons.SearchIcon, {
539
- scale: "medium",
551
+ size: "medium",
540
552
  color: "primary"
541
553
  })
542
554
  });
@@ -554,6 +566,10 @@ var selectInputComponents = {
554
566
  DropdownIndicator: DropdownIndicator
555
567
  };
556
568
  var ColumnSettingsManager = function ColumnSettingsManager(props) {
569
+ if (props.areHiddenColumnsSearchable) {
570
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
571
+ }
572
+
557
573
  var intl = reactIntl.useIntl();
558
574
 
559
575
  var _useState = react.useState(false),
@@ -575,9 +591,9 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
575
591
  var handleDragEnd = react.useCallback(function (dragResult) {
576
592
  return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
577
593
  }, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
578
- var handleInputChange = react.useCallback(function (input) {
594
+ var handleInputChange = react.useCallback(function (inputValue) {
579
595
  return (// loadOptions is not invoked when input is empty
580
- !input.length && searchHiddenColumns(input)
596
+ !inputValue.length && (searchHiddenColumns === null || searchHiddenColumns === void 0 ? void 0 : searchHiddenColumns(inputValue))
581
597
  );
582
598
  }, [searchHiddenColumns]);
583
599
  return jsxRuntime.jsx(SettingsContainer$1, {
@@ -616,7 +632,7 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
616
632
  // because the loading indicator is displayed
617
633
  // only when loadOptions is invoked
618
634
  ,
619
- loadOptions: debounce__default["default"](searchHiddenColumns, 300),
635
+ loadOptions: debounce__default["default"](searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300),
620
636
  onInputChange: handleInputChange,
621
637
  components: selectInputComponents
622
638
  })), jsxRuntime.jsx(DroppablePanel$1, {
@@ -653,30 +669,29 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
653
669
  })
654
670
  });
655
671
  };
656
- ColumnSettingsManager.displayName = 'ColumnSettingsManager';
657
672
  ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
658
- availableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
659
- key: PropTypes__default["default"].string.isRequired,
660
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
673
+ availableColumns: _pt__default["default"].arrayOf(_pt__default["default"].shape({
674
+ key: _pt__default["default"].string.isRequired,
675
+ label: _pt__default["default"].node.isRequired
661
676
  })).isRequired,
662
- selectedColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
663
- key: PropTypes__default["default"].string.isRequired,
664
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
677
+ selectedColumns: _pt__default["default"].arrayOf(_pt__default["default"].shape({
678
+ key: _pt__default["default"].string.isRequired,
679
+ label: _pt__default["default"].node.isRequired
665
680
  })).isRequired,
666
- onUpdateColumns: PropTypes__default["default"].func.isRequired,
667
- areHiddenColumnsSearchable: PropTypes__default["default"].bool,
668
- searchHiddenColumns: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
669
- return props.areHiddenColumnsSearchable;
670
- }),
671
- searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
672
- onClose: PropTypes__default["default"].func,
673
- primaryButton: PropTypes__default["default"].element,
674
- secondaryButton: PropTypes__default["default"].element,
675
- managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
681
+ onUpdateColumns: _pt__default["default"].func.isRequired,
682
+ areHiddenColumnsSearchable: _pt__default["default"].bool,
683
+ searchHiddenColumns: _pt__default["default"].func,
684
+ searchHiddenColumnsPlaceholder: _pt__default["default"].string,
685
+ onClose: _pt__default["default"].func.isRequired,
686
+ primaryButton: _pt__default["default"].element,
687
+ secondaryButton: _pt__default["default"].element,
688
+ managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
676
689
  } : {};
677
- ColumnSettingsManager.defaultProps = {
690
+ ColumnSettingsManager.displayName = 'ColumnSettingsManager';
691
+ var defaultProps = {
678
692
  availableColumns: []
679
693
  };
694
+ ColumnSettingsManager.defaultProps = defaultProps;
680
695
  var ColumnSettingsManager$1 = ColumnSettingsManager;
681
696
 
682
697
  var messages = reactIntl.defineMessages({
@@ -703,17 +718,20 @@ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) {
703
718
 
704
719
  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)."; }
705
720
 
721
+ /* The horizontal constraint is set on this container instead of the SelectInput
722
+ because the input is always empty, and therefore doesn't take any space by itself
723
+ but we want to keep enough space for the placeholder to be readable */
706
724
  var SelectContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
707
- target: "eh8k7x01"
725
+ target: "e3i1gnv1"
708
726
  } : {
709
- target: "eh8k7x01",
727
+ target: "e3i1gnv1",
710
728
  label: "SelectContainer"
711
- })("width:", designSystem.customProperties.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAqBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\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';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\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 = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\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(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\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\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';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */"));
729
+ })("width:", designSystem.customProperties.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AA8HkC","file":"data-table-settings.tsx","sourcesContent":["import { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\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';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<unknown>;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\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\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\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>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\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\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"]} */"));
712
730
 
713
731
  var TopBarContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
714
- target: "eh8k7x00"
732
+ target: "e3i1gnv0"
715
733
  } : {
716
- target: "eh8k7x00",
734
+ target: "e3i1gnv0",
717
735
  label: "TopBarContainer"
718
736
  })(process.env.NODE_ENV === "production" ? {
719
737
  name: "1ff36h2",
@@ -721,7 +739,7 @@ var TopBarContainer = _styled__default["default"]("div", process.env.NODE_ENV ==
721
739
  } : {
722
740
  name: "1ff36h2",
723
741
  styles: "flex-grow:1",
724
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAyBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\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';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\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 = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\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(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\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\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';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */",
742
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAkIkC","file":"data-table-settings.tsx","sourcesContent":["import { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\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';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<unknown>;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\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\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\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>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\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\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"]} */",
725
743
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
726
744
  });
727
745
 
@@ -753,6 +771,8 @@ var getSelectedColumns = function getSelectedColumns(mappedColumns) {
753
771
  };
754
772
 
755
773
  var DataTableSettings = function DataTableSettings(props) {
774
+ var _props$columnManager$, _props$columnManager;
775
+
756
776
  var areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
757
777
  var areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
758
778
  process.env.NODE_ENV !== "production" ? utils.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;
@@ -770,7 +790,7 @@ var DataTableSettings = function DataTableSettings(props) {
770
790
  });
771
791
 
772
792
  var handleDropdownChange = function handleDropdownChange(event) {
773
- return setOpenedPanelId(event.target.value);
793
+ return setOpenedPanelId(_Array$isArray__default["default"](event.target.value) ? event.target.value[0] : event.target.value);
774
794
  };
775
795
 
776
796
  var mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
@@ -806,54 +826,60 @@ var DataTableSettings = function DataTableSettings(props) {
806
826
  }), openedPanelId === DISPLAY_SETTINGS && jsxRuntime.jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
807
827
  onClose: handleSettingsPanelChange,
808
828
  onDensityDisplayChange: function onDensityDisplayChange(event) {
809
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
829
+ var _props$onSettingsChan;
830
+
831
+ (_props$onSettingsChan = props.onSettingsChange) === null || _props$onSettingsChan === void 0 ? void 0 : _props$onSettingsChan.call(props, UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
810
832
  },
811
833
  onTextWrappingChange: function onTextWrappingChange(event) {
812
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
834
+ var _props$onSettingsChan2;
835
+
836
+ (_props$onSettingsChan2 = props.onSettingsChange) === null || _props$onSettingsChan2 === void 0 ? void 0 : _props$onSettingsChan2.call(props, UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
813
837
  },
814
838
  managerTheme: props.managerTheme
815
839
  })), openedPanelId === COLUMN_MANAGER && jsxRuntime.jsx(ColumnSettingsManager$1, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
816
- availableColumns: props.columnManager.hideableColumns,
840
+ availableColumns: (_props$columnManager$ = (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
817
841
  selectedColumns: selectedColumns,
818
842
  onClose: handleSettingsPanelChange,
819
843
  onUpdateColumns: function onUpdateColumns(nextVisibleColumns) {
844
+ var _props$onSettingsChan3;
845
+
820
846
  var keysOfVisibleColumns = _mapInstanceProperty__default["default"](nextVisibleColumns).call(nextVisibleColumns, function (visibleColumn) {
821
847
  return visibleColumn.key;
822
848
  });
823
849
 
824
- props.onSettingsChange(UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
850
+ (_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 ? void 0 : _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
825
851
  },
826
852
  managerTheme: props.managerTheme
827
853
  }))]
828
854
  });
829
855
  };
830
856
 
831
- DataTableSettings.displayName = 'DataTableSettings';
832
857
  DataTableSettings.propTypes = process.env.NODE_ENV !== "production" ? {
833
- topBar: PropTypes__default["default"].node,
834
- onSettingsChange: PropTypes__default["default"].func,
835
- displaySettings: PropTypes__default["default"].shape({
836
- disableDisplaySettings: PropTypes__default["default"].bool,
837
- isCondensed: PropTypes__default["default"].bool,
838
- isWrappingText: PropTypes__default["default"].bool,
839
- primaryButton: PropTypes__default["default"].element,
840
- secondaryButton: PropTypes__default["default"].element
858
+ topBar: _pt__default["default"].node,
859
+ onSettingsChange: _pt__default["default"].func,
860
+ displaySettings: _pt__default["default"].shape({
861
+ disableDisplaySettings: _pt__default["default"].bool,
862
+ isCondensed: _pt__default["default"].bool,
863
+ isWrappingText: _pt__default["default"].bool,
864
+ primaryButton: _pt__default["default"].element,
865
+ secondaryButton: _pt__default["default"].element
841
866
  }),
842
- columnManager: PropTypes__default["default"].shape({
843
- areHiddenColumnsSearchable: PropTypes__default["default"].bool,
844
- disableColumnManager: PropTypes__default["default"].bool,
845
- visibleColumnKeys: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string.isRequired),
846
- hideableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
847
- key: PropTypes__default["default"].string.isRequired,
848
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
867
+ columnManager: _pt__default["default"].shape({
868
+ areHiddenColumnsSearchable: _pt__default["default"].bool,
869
+ disableColumnManager: _pt__default["default"].bool,
870
+ visibleColumnKeys: _pt__default["default"].arrayOf(_pt__default["default"].string).isRequired,
871
+ hideableColumns: _pt__default["default"].arrayOf(_pt__default["default"].shape({
872
+ key: _pt__default["default"].string.isRequired,
873
+ label: _pt__default["default"].node.isRequired
849
874
  })),
850
- searchHiddenColumns: PropTypes__default["default"].func,
851
- searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
852
- primaryButton: PropTypes__default["default"].element,
853
- secondaryButton: PropTypes__default["default"].element
875
+ searchHiddenColumns: _pt__default["default"].func,
876
+ searchHiddenColumnsPlaceholder: _pt__default["default"].string,
877
+ primaryButton: _pt__default["default"].element,
878
+ secondaryButton: _pt__default["default"].element
854
879
  }),
855
- managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
880
+ managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
856
881
  } : {};
882
+ DataTableSettings.displayName = 'DataTableSettings';
857
883
  var DataTableSettings$1 = DataTableSettings;
858
884
 
859
885
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
@@ -887,233 +913,29 @@ var DataTableManager = function DataTableManager(props) {
887
913
  };
888
914
 
889
915
  DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
890
- /**
891
- * Each object requires a unique `key` which should correspond to property key of
892
- * the items of `rows` that you want to render under this column, and a `label`
893
- * which defines the name shown on the header.
894
- * The list of columns to be rendered.
895
- * Each column can be customized (see properties below).
896
- */
897
- columns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
898
- /**
899
- * The unique key of the column that is used to identify your data type.
900
- * You can use this value to determine which value from a row item should be rendered.
901
- * <br>
902
- * For example, if the data is a list of users, where each user has a `firstName` property,
903
- * the column key should be `firstName`, which renders the correct value by default.
904
- * The key can also be some custom or computed value, in which case you need to provide
905
- * an explicit mapping of the value by implementing either the `itemRendered` function or
906
- * the column-specific `renderItem` function.
907
- */
908
- key: PropTypes__default["default"].string.isRequired,
909
-
910
- /**
911
- * The label of the column that will be shown on the column header.
912
- */
913
- label: PropTypes__default["default"].node.isRequired,
914
-
915
- /**
916
- * Sets a width for this column. Accepts the same values as the ones specified for
917
- * individual [grid-template-columns](https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-columns).
918
- * <br>
919
- * For example, using `minmax` pairs (e.g. `minmax(200px, 400px)`), a combinations of
920
- * fraction values (`1fr`/`2fr`/etc), or fixed values such as `200px`.
921
- * By default, the column grows according to the content and respecting the total table available width.
922
- *
923
- * @@defaultValue@@: auto
924
- */
925
- width: PropTypes__default["default"].string,
926
-
927
- /**
928
- * Use this to override the table's own `horizontalCellAlignment` prop for this specific column.
929
- */
930
- align: PropTypes__default["default"].oneOf(['left', 'center', 'right']),
931
-
932
- /**
933
- * A callback function, called when the header cell is clicked.
934
- * <br>
935
- * Signature: `(event) => void`
936
- */
937
- onClick: PropTypes__default["default"].func,
938
-
939
- /**
940
- * A callback function to render the content of cells under this column, overriding
941
- * the default `itemRenderer` prop of the table.
942
- * <br>
943
- * Signature: `(row: object, isRowCollapsed: boolean) => React.Node`
944
- */
945
- renderItem: PropTypes__default["default"].func,
946
-
947
- /**
948
- * Use this prop to place an `Icon` or `IconButton` on the left of the column label.
949
- * It is advised to place these types of components through this prop instead of `label`,
950
- * in order to properly position and align the elements.
951
- * This is particularly useful for medium-sized icons which require more vertical space than the typography.
952
- */
953
- headerIcon: PropTypes__default["default"].node,
954
-
955
- /**
956
- * Set this to `true` to allow text content of this cell to be truncated with an ellipsis,
957
- * instead of breaking into multiple lines.
958
- * <br>
959
- * NOTE: when using this option, it is recommended to specify a `width` for the column, because
960
- * if the table doesn't have enough space for all columns, it will start clipping the columns
961
- * with _truncated_ content, and if no `width` is set (or the value is set `auto` -- the default)
962
- * it can shrink until the column disappears completely.
963
- * By enforcing a minimum width for these columns, the table will respect them and grow horizontally,
964
- * adding scrollbars if needed.
965
- *
966
- * @@defaultValue@@: false
967
- */
968
- isTruncated: PropTypes__default["default"].bool,
969
-
970
- /**
971
- * Set this to `true` to show a sorting button, which calls `onSortChange` upon being clicked.
972
- * You should enable this flag for every column you want to be able to sort.
973
- * When at least one column is sortable, the table props `sortBy`, `sortDirection` and `onSortChange` should be provided.
974
- *
975
- * @@defaultValue@@: false
976
- */
977
- isSortable: PropTypes__default["default"].bool,
978
-
979
- /**
980
- * Set this to `true` to prevent this column from being manually resized by dragging
981
- * the edge of the header with a mouse.
982
- *
983
- * @@defaultValue@@: false
984
- */
985
- disableResizing: PropTypes__default["default"].bool,
986
-
987
- /**
988
- * Set this to `true` to prevent click event propagation for this cell.
989
- * You might want this if you need the column to have its own call-to-action or input while
990
- * the row also has a defined `onRowClick`.
991
- *
992
- * @@defaultValue@@: false
993
- */
994
- shouldIgnoreRowClick: PropTypes__default["default"].bool
916
+ columns: _pt__default["default"].arrayOf(_pt__default["default"].shape({
917
+ key: _pt__default["default"].string.isRequired,
918
+ label: _pt__default["default"].node.isRequired,
919
+ width: _pt__default["default"].string,
920
+ align: _pt__default["default"].oneOf(['left', 'center', 'right']),
921
+ onClick: _pt__default["default"].func,
922
+ renderItem: _pt__default["default"].func,
923
+ headerIcon: _pt__default["default"].node,
924
+ isTruncated: _pt__default["default"].bool,
925
+ isSortable: _pt__default["default"].bool,
926
+ disableResizing: _pt__default["default"].bool,
927
+ shouldIgnoreRowClick: _pt__default["default"].bool
995
928
  })).isRequired,
996
-
997
- /**
998
- * Any React node. Usually you want to render the `<DataTable>` component.
999
- * <br>
1000
- * Note that the child component will implicitly receive the props `columns` and `isCondensed` from the `<DataTableManager>`.
1001
- */
1002
- children: PropTypes__default["default"].node.isRequired,
1003
-
1004
- /**
1005
- * The managed display settings of the table.
1006
- */
1007
- displaySettings: PropTypes__default["default"].shape({
1008
- /**
1009
- * Set this flag to `false` to show the display settings panel option.
1010
- *
1011
- * @@defaultValue@@: true
1012
- */
1013
- disableDisplaySettings: PropTypes__default["default"].bool,
1014
-
1015
- /**
1016
- * Set this to `true` to reduce the paddings of all cells, allowing the table to display
1017
- * more data in less space.
1018
- *
1019
- * @@defaultValue@@: false
1020
- */
1021
- isCondensed: PropTypes__default["default"].bool,
1022
-
1023
- /**
1024
- * Set this to `true` to allow text in a cell to wrap.
1025
- * <br>
1026
- * This is required if `disableDisplaySettings` is set to `false`.
1027
- *
1028
- * @@defaultValue@@: false
1029
- */
1030
- isWrappingText: PropTypes__default["default"].bool,
1031
-
1032
- /**
1033
- * A React element to be rendered as the primary button, useful when the display settings work as a form.
1034
- */
1035
- primaryButton: PropTypes__default["default"].element,
1036
-
1037
- /**
1038
- * A React element to be rendered as the secondary button, useful when the display settings work as a form.
1039
- */
1040
- secondaryButton: PropTypes__default["default"].element
1041
- }),
1042
-
1043
- /**
1044
- * The managed column settings of the table.
1045
- */
1046
- columnManager: PropTypes__default["default"].shape({
1047
- /**
1048
- * Set this to `false` to show the column settings panel option.
1049
- *
1050
- * @@defaultValue@@: true
1051
- */
1052
- disableColumnManager: PropTypes__default["default"].bool,
1053
-
1054
- /**
1055
- * The keys of the visible columns.
1056
- */
1057
- visibleColumnKeys: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string.isRequired),
1058
-
1059
- /**
1060
- * The keys of the visible columns.
1061
- */
1062
- hideableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1063
- key: PropTypes__default["default"].string.isRequired,
1064
- label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
1065
- })),
1066
-
1067
- /**
1068
- * Set this to `true` to show a search input for the hidden columns panel.
1069
- */
1070
- areHiddenColumnsSearchable: PropTypes__default["default"].bool,
1071
-
1072
- /**
1073
- * A callback function, called when the search input for the hidden columns panel changes.
1074
- * <br>
1075
- * Signature: `(event) => void`
1076
- */
1077
- searchHiddenColumns: PropTypes__default["default"].func,
1078
-
1079
- /**
1080
- * Placeholder value of the search input for the hidden columns panel.
1081
- */
1082
- searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
1083
-
1084
- /**
1085
- * A React element to be rendered as the primary button, useful when the column settings work as a form.
1086
- */
1087
- primaryButton: PropTypes__default["default"].element,
1088
-
1089
- /**
1090
- * A React element to be rendered as the secondary button, useful when the column settings work as a form.
1091
- */
1092
- secondaryButton: PropTypes__default["default"].element
1093
- }),
1094
-
1095
- /**
1096
- * A callback function, called when any of the properties of either display settings or column settings is modified.
1097
- * <br>
1098
- * Signature: `(action: string, nextValue: object) => void`
1099
- */
1100
- onSettingsChange: PropTypes__default["default"].func,
1101
-
1102
- /**
1103
- * A React node for rendering additional information within the table manager.
1104
- */
1105
- topBar: PropTypes__default["default"].node,
1106
-
1107
- /**
1108
- * Sets the background theme of the Card that contains the settings
1109
- */
1110
- managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
929
+ children: _pt__default["default"].element.isRequired,
930
+ onSettingsChange: _pt__default["default"].func,
931
+ topBar: _pt__default["default"].node,
932
+ managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
1111
933
  } : {};
1112
934
  DataTableManager.displayName = 'DataTableManager';
1113
935
  var DataTableManager$1 = DataTableManager;
1114
936
 
1115
937
  // NOTE: This string will be replaced on build time with the package version.
1116
- var version = "13.0.3";
938
+ var version = "13.0.4";
1117
939
 
1118
940
  Object.defineProperty(exports, 'useRowSelection', {
1119
941
  enumerable: true,