@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
@@ -1,3 +1,6 @@
1
+ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
2
+ import _pt from 'prop-types';
3
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
1
4
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
2
5
  import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
3
6
  import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
@@ -6,9 +9,6 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
6
9
  import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
7
10
  import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
8
11
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
- import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
- import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
11
- import PropTypes from 'prop-types';
12
12
  import { useState, useMemo, useCallback, cloneElement } from 'react';
13
13
  import Spacings from '@commercetools-uikit/spacings';
14
14
  import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
@@ -17,6 +17,7 @@ import _toConsumableArray from '@babel/runtime-corejs3/helpers/esm/toConsumableA
17
17
  import _styled from '@emotion/styled/base';
18
18
  import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
19
19
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
20
+ import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
20
21
  import { warning } from '@commercetools-uikit/utils';
21
22
  import { useIntl, defineMessages } from 'react-intl';
22
23
  import AccessibleHiden from '@commercetools-uikit/accessible-hidden';
@@ -30,9 +31,9 @@ import AccessibleButton from '@commercetools-uikit/accessible-button';
30
31
  import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
31
32
  import Card from '@commercetools-uikit/card';
32
33
  import Text from '@commercetools-uikit/text';
34
+ import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
33
35
  import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
34
36
  import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
35
- import requiredIf from 'react-required-if';
36
37
  import { Draggable, Droppable, DragDropContext } from 'react-beautiful-dnd';
37
38
  import debounce from 'debounce-promise';
38
39
  import differenceWith from 'lodash/differenceWith';
@@ -51,9 +52,9 @@ var DISPLAY_SETTINGS = 'displaySettings';
51
52
  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)."; }
52
53
 
53
54
  var HeaderContainer = _styled("div", process.env.NODE_ENV === "production" ? {
54
- target: "e16v1mgb0"
55
+ target: "e6ezr100"
55
56
  } : {
56
- target: "e16v1mgb0",
57
+ target: "e6ezr100",
57
58
  label: "HeaderContainer"
58
59
  })(process.env.NODE_ENV === "production" ? {
59
60
  name: "1bhm8h2",
@@ -61,7 +62,7 @@ var HeaderContainer = _styled("div", process.env.NODE_ENV === "production" ? {
61
62
  } : {
62
63
  name: "1bhm8h2",
63
64
  styles: "display:flex;flex:1;justify-content:space-between",
64
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0MiLCJmaWxlIjoic2V0dGluZ3MtY29udGFpbmVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cImZsYXRcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgzXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICA8QWNjZXNzaWJsZUJ1dHRvblxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9e3Byb3BzLm9uQ2xvc2V9XG4gICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxDbG9zZUljb24gc2l6ZT1cIm1lZGl1bVwiIC8+XG4gICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgIDwvSGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgc3R5bGU9e2NvbnRhaW5lclN0eWxlc30+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLkluc2V0PlxuICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICB7cHJvcHMuc2Vjb25kYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblNldHRpbmdzQ29udGFpbmVyLnByb3BUeXBlcyA9IHtcbiAgdGl0bGU6IFByb3BUeXBlcy5zaGFwZSh7XG4gICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBkZWZhdWx0TWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICB9KS5pc1JlcXVpcmVkLFxuICBjbG9zZUJ1dHRvbkxhYmVsOiBQcm9wVHlwZXMuc2hhcGUoe1xuICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgZGVmYXVsdE1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgfSkuaXNSZXF1aXJlZCxcbiAgb25DbG9zZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgcHJpbWFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIHNlY29uZGFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICBjb250YWluZXJUaGVtZTogUHJvcFR5cGVzLm9uZU9mKFsnbGlnaHQnLCAnZGFyayddKSxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
65
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbnR5cGUgVFNldHRpbmdzQ29udGFpbmVyUHJvcHMgPSB7XG4gIHRpdGxlOiBNZXNzYWdlRGVzY3JpcHRvciAmIHtcbiAgICB2YWx1ZXM/OiBSZWNvcmQ8c3RyaW5nLCBSZWFjdC5SZWFjdE5vZGU+O1xuICB9O1xuICBjbG9zZUJ1dHRvbkxhYmVsOiBNZXNzYWdlRGVzY3JpcHRvciAmIHtcbiAgICB2YWx1ZXM/OiBSZWNvcmQ8c3RyaW5nLCBSZWFjdC5SZWFjdE5vZGU+O1xuICB9O1xuICBvbkNsb3NlOiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICBwcmltYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBzZWNvbmRhcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIGNvbnRhaW5lclRoZW1lPzogJ2xpZ2h0JyB8ICdkYXJrJztcbn07XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzOiBUU2V0dGluZ3NDb250YWluZXJQcm9wcykgPT4ge1xuICBjb25zdCBpbnRsID0gdXNlSW50bCgpO1xuXG4gIHJldHVybiAoXG4gICAgPENvbGxhcHNpYmxlTW90aW9uIGlzRGVmYXVsdENsb3NlZD17ZmFsc2V9PlxuICAgICAgeyh7IHJlZ2lzdGVyQ29udGVudE5vZGUsIGNvbnRhaW5lclN0eWxlcyB9KSA9PiAoXG4gICAgICAgIDxDYXJkIHR5cGU9XCJmbGF0XCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4c1wiPlxuICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoM1wiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgPEFjY2Vzc2libGVCdXR0b25cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgIGxhYmVsPXtpbnRsLmZvcm1hdE1lc3NhZ2UocHJvcHMuY2xvc2VCdXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICA8L0FjY2Vzc2libGVCdXR0b24+XG4gICAgICAgICAgICA8L0hlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbnNldCBzY2FsZT1cInNcIj5cbiAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUganVzdGlmeUNvbnRlbnQ9XCJmbGV4LWVuZFwiPlxuICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICA8L0NhcmQ+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gICk7XG59O1xuXG5TZXR0aW5nc0NvbnRhaW5lci5kaXNwbGF5TmFtZSA9ICdTZXR0aW5nc0NvbnRhaW5lcic7XG5cbmNvbnN0IGRlZmF1bHRQcm9wczogUGljazxUU2V0dGluZ3NDb250YWluZXJQcm9wcywgJ2NvbnRhaW5lclRoZW1lJz4gPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuU2V0dGluZ3NDb250YWluZXIuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
65
66
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
66
67
  });
67
68
 
@@ -110,25 +111,24 @@ var SettingsContainer = function SettingsContainer(props) {
110
111
  });
111
112
  };
112
113
 
113
- SettingsContainer.displayName = 'SettingsContainer';
114
114
  SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
115
- title: PropTypes.shape({
116
- id: PropTypes.string.isRequired,
117
- defaultMessage: PropTypes.string.isRequired
118
- }).isRequired,
119
- closeButtonLabel: PropTypes.shape({
120
- id: PropTypes.string.isRequired,
121
- defaultMessage: PropTypes.string.isRequired
122
- }).isRequired,
123
- onClose: PropTypes.func.isRequired,
124
- primaryButton: PropTypes.element,
125
- secondaryButton: PropTypes.element,
126
- children: PropTypes.node.isRequired,
127
- containerTheme: PropTypes.oneOf(['light', 'dark'])
115
+ title: _pt.oneOfType([_pt.any, _pt.shape({
116
+ values: _pt.objectOf(_pt.node)
117
+ })]).isRequired,
118
+ closeButtonLabel: _pt.oneOfType([_pt.any, _pt.shape({
119
+ values: _pt.objectOf(_pt.node)
120
+ })]).isRequired,
121
+ onClose: _pt.func.isRequired,
122
+ primaryButton: _pt.element,
123
+ secondaryButton: _pt.element,
124
+ children: _pt.node.isRequired,
125
+ containerTheme: _pt.oneOf(['light', 'dark'])
128
126
  } : {};
129
- SettingsContainer.defaultProps = {
127
+ SettingsContainer.displayName = 'SettingsContainer';
128
+ var defaultProps$2 = {
130
129
  containerTheme: 'dark'
131
130
  };
131
+ SettingsContainer.defaultProps = defaultProps$2;
132
132
  var SettingsContainer$1 = SettingsContainer;
133
133
 
134
134
  var messages$3 = defineMessages({
@@ -252,29 +252,30 @@ var DensityManager = function DensityManager(props) {
252
252
  });
253
253
  };
254
254
 
255
+ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
256
+ isCondensed: _pt.bool,
257
+ isWrappingText: _pt.bool,
258
+ primaryButton: _pt.element,
259
+ secondaryButton: _pt.element,
260
+ onDensityDisplayChange: _pt.func.isRequired,
261
+ onTextWrappingChange: _pt.func.isRequired,
262
+ onClose: _pt.func.isRequired,
263
+ managerTheme: _pt.oneOf(['light', 'dark'])
264
+ } : {};
255
265
  DensityManager.displayName = 'DensityManager';
256
- DensityManager.defaultProps = {
266
+ var defaultProps$1 = {
257
267
  isCondensed: false,
258
268
  isWrappingText: false
259
269
  };
260
- DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
261
- isCondensed: PropTypes.bool,
262
- isWrappingText: PropTypes.bool,
263
- primaryButton: PropTypes.element,
264
- secondaryButton: PropTypes.element,
265
- onDensityDisplayChange: PropTypes.func.isRequired,
266
- onTextWrappingChange: PropTypes.func.isRequired,
267
- onClose: PropTypes.func.isRequired,
268
- managerTheme: PropTypes.oneOf(['light', 'dark'])
269
- } : {};
270
+ DensityManager.defaultProps = defaultProps$1;
270
271
  var DisplaySettingsManager = DensityManager;
271
272
 
272
273
  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)."; }
273
274
 
274
275
  var DraggingSmall = _styled("small", process.env.NODE_ENV === "production" ? {
275
- target: "ed3a5rx1"
276
+ target: "e1mp438g1"
276
277
  } : {
277
- target: "ed3a5rx1",
278
+ target: "e1mp438g1",
278
279
  label: "DraggingSmall"
279
280
  })(process.env.NODE_ENV === "production" ? {
280
281
  name: "1fhyj3b",
@@ -282,16 +283,16 @@ var DraggingSmall = _styled("small", process.env.NODE_ENV === "production" ? {
282
283
  } : {
283
284
  name: "1fhyj3b",
284
285
  styles: "&:hover{cursor:grab;}",
285
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVrQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */",
286
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFa0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */",
286
287
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
287
288
  });
288
289
 
289
290
  var DraggingContainer = _styled("div", process.env.NODE_ENV === "production" ? {
290
- target: "ed3a5rx0"
291
+ target: "e1mp438g0"
291
292
  } : {
292
- target: "ed3a5rx0",
293
+ target: "e1mp438g0",
293
294
  label: "DraggingContainer"
294
- })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFvQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */"));
295
+ })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRb0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */"));
295
296
 
296
297
  var DraggingContainer$1 = DraggingContainer;
297
298
 
@@ -301,7 +302,9 @@ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) {
301
302
 
302
303
  var DraggableTag = function DraggableTag(props) {
303
304
  var handleRemoveColumn = function handleRemoveColumn() {
304
- return props.onRemove(props.index);
305
+ var _props$onRemove;
306
+
307
+ return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
305
308
  };
306
309
 
307
310
  return jsx(Draggable, {
@@ -309,9 +312,9 @@ var DraggableTag = function DraggableTag(props) {
309
312
  index: props.index,
310
313
  isDragDisabled: props.isDisabled,
311
314
  children: function children(provided) {
312
- return jsxs(Spacings.Inset, {
315
+ return jsx(Spacings.Inset, {
313
316
  scale: "xs",
314
- children: [jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
317
+ children: jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
315
318
  ref: provided.innerRef
316
319
  }, provided.draggableProps), provided.dragHandleProps), {}, {
317
320
  children: jsx(Tag, {
@@ -325,30 +328,30 @@ var DraggableTag = function DraggableTag(props) {
325
328
  }), props.column.label]
326
329
  })
327
330
  })
328
- })), provided.placeholder]
331
+ }))
329
332
  });
330
333
  }
331
334
  });
332
335
  };
333
336
 
334
- DraggableTag.displayName = 'DraggableTag';
335
337
  DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
336
- column: PropTypes.shape({
337
- key: PropTypes.string.isRequired,
338
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
338
+ column: _pt.shape({
339
+ key: _pt.string.isRequired,
340
+ label: _pt.node.isRequired
339
341
  }).isRequired,
340
- index: PropTypes.number.isRequired,
341
- onRemove: PropTypes.func,
342
- isDisabled: PropTypes.bool
342
+ index: _pt.number.isRequired,
343
+ isDisabled: _pt.bool,
344
+ onRemove: _pt.func
343
345
  } : {};
346
+ DraggableTag.displayName = 'DraggableTag';
344
347
  var DraggableTag$1 = DraggableTag;
345
348
 
346
349
  var TagContainerEditable = _styled("div", process.env.NODE_ENV === "production" ? {
347
- target: "ecy2q1d0"
350
+ target: "e7rakq0"
348
351
  } : {
349
- target: "ecy2q1d0",
352
+ target: "e7rakq0",
350
353
  label: "TagContainerEditable"
351
- })("background-color:", customProperties.backgroundColorForInput, ";border:", customProperties.borderRadius1, " solid ", customProperties.colorNeutral60, ";border-radius:", customProperties.borderRadius6, ";padding:", customProperties.spacingS, ";height:", customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR3VDIiwiZmlsZSI6InRhZy1jb250YWluZXItZWRpdGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgVGFnQ29udGFpbmVyRWRpdGFibGUgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXR9O1xuICBib3JkZXI6ICR7dmFycy5ib3JkZXJSYWRpdXMxfSBzb2xpZCAke3ZhcnMuY29sb3JOZXV0cmFsNjB9O1xuICBib3JkZXItcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzNn07XG4gIHBhZGRpbmc6ICR7dmFycy5zcGFjaW5nU307XG4gIGhlaWdodDogJHt2YXJzLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
354
+ })("background-color:", customProperties.backgroundColorForInput, ";border:", customProperties.borderRadius1, " solid ", customProperties.colorNeutral60, ";border-radius:", customProperties.borderRadius6, ";padding:", customProperties.spacingS, ";height:", customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7dmFycy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dH07XG4gIGJvcmRlcjogJHt2YXJzLmJvcmRlclJhZGl1czF9IHNvbGlkICR7dmFycy5jb2xvck5ldXRyYWw2MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXM2fTtcbiAgcGFkZGluZzogJHt2YXJzLnNwYWNpbmdTfTtcbiAgaGVpZ2h0OiAke3ZhcnMuY29uc3RyYWludDd9O1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IFRhZ0NvbnRhaW5lckVkaXRhYmxlO1xuIl19 */"));
352
355
 
353
356
  var TagContainerEditable$1 = TagContainerEditable;
354
357
 
@@ -402,18 +405,18 @@ var DroppablePanel = function DroppablePanel(props) {
402
405
  });
403
406
  };
404
407
 
405
- DroppablePanel.displayName = 'DroppablePanel';
406
408
  DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
407
- droppableId: PropTypes.string.isRequired,
408
- noColumnsText: PropTypes.node.isRequired,
409
- columns: PropTypes.arrayOf(PropTypes.shape({
410
- key: PropTypes.string.isRequired,
411
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
412
- })),
413
- isSearchable: PropTypes.bool,
414
- isDisabled: PropTypes.bool,
415
- onRemove: PropTypes.func
409
+ droppableId: _pt.string.isRequired,
410
+ noColumnsText: _pt.node.isRequired,
411
+ columns: _pt.arrayOf(_pt.shape({
412
+ key: _pt.string.isRequired,
413
+ label: _pt.node.isRequired
414
+ })).isRequired,
415
+ isSearchable: _pt.bool,
416
+ isDisabled: _pt.bool,
417
+ onRemove: _pt.func
416
418
  } : {};
419
+ DroppablePanel.displayName = 'DroppablePanel';
417
420
  var DroppablePanel$1 = DroppablePanel;
418
421
 
419
422
  var messages$1 = defineMessages({
@@ -456,14 +459,18 @@ function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if
456
459
 
457
460
  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(_context4 = ownKeys$2(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context5 = ownKeys$2(Object(source))).call(_context5, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
458
461
 
462
+ var noSearch = function noSearch() {
463
+ return _Promise.resolve();
464
+ };
465
+
459
466
  var DroppableContainer = _styled("div", process.env.NODE_ENV === "production" ? {
460
- target: "e6ge22w0"
467
+ target: "en01od20"
461
468
  } : {
462
- target: "e6ge22w0",
469
+ target: "en01od20",
463
470
  label: "DroppableContainer"
464
471
  })("width:100%;position:relative;max-width:", customProperties.constraint10, ";cursor:", function (props) {
465
472
  return props.isDragging ? 'grabbing' : 'auto';
466
- }, ";" + (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"]} */"));
473
+ }, ";" + (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"]} */"));
467
474
 
468
475
  var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) {
469
476
  setIsDragging(false); // Invalid drop destination, do nothing
@@ -476,7 +483,7 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
476
483
  if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
477
484
  onUpdateColumns(_concatInstanceProperty(_context = []).call(_context, _toConsumableArray(_sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index)), _toConsumableArray(_sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1))));
478
485
  } else {
479
- var _context2, _context3;
486
+ var _context2;
480
487
 
481
488
  // the destination is the selected columns panel
482
489
  // it's a swap when the source and the destination are the same
@@ -488,10 +495,14 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
488
495
 
489
496
  var draggedColumn = _findInstanceProperty(columns).call(columns, function (col) {
490
497
  return col.key === dragResult.draggableId;
491
- }); // push the column in the new position
498
+ }); // push the column in the new position if draggedColumn is found
492
499
 
493
500
 
494
- onUpdateColumns(_concatInstanceProperty(_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty(items).call(items, 0, dragResult.destination.index)), [draggedColumn], _toConsumableArray(_sliceInstanceProperty(items).call(items, dragResult.destination.index))));
501
+ if (draggedColumn) {
502
+ var _context3;
503
+
504
+ onUpdateColumns(_concatInstanceProperty(_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty(items).call(items, 0, dragResult.destination.index)), [draggedColumn], _toConsumableArray(_sliceInstanceProperty(items).call(items, dragResult.destination.index))));
505
+ }
495
506
  }
496
507
  };
497
508
 
@@ -499,7 +510,7 @@ var DropdownIndicator = function DropdownIndicator() {
499
510
  return jsx(Spacings.Inline, {
500
511
  alignItems: "center",
501
512
  children: jsx(SearchIcon, {
502
- scale: "medium",
513
+ size: "medium",
503
514
  color: "primary"
504
515
  })
505
516
  });
@@ -517,6 +528,10 @@ var selectInputComponents = {
517
528
  DropdownIndicator: DropdownIndicator
518
529
  };
519
530
  var ColumnSettingsManager = function ColumnSettingsManager(props) {
531
+ if (props.areHiddenColumnsSearchable) {
532
+ process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
533
+ }
534
+
520
535
  var intl = useIntl();
521
536
 
522
537
  var _useState = useState(false),
@@ -538,9 +553,9 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
538
553
  var handleDragEnd = useCallback(function (dragResult) {
539
554
  return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
540
555
  }, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
541
- var handleInputChange = useCallback(function (input) {
556
+ var handleInputChange = useCallback(function (inputValue) {
542
557
  return (// loadOptions is not invoked when input is empty
543
- !input.length && searchHiddenColumns(input)
558
+ !inputValue.length && (searchHiddenColumns === null || searchHiddenColumns === void 0 ? void 0 : searchHiddenColumns(inputValue))
544
559
  );
545
560
  }, [searchHiddenColumns]);
546
561
  return jsx(SettingsContainer$1, {
@@ -579,7 +594,7 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
579
594
  // because the loading indicator is displayed
580
595
  // only when loadOptions is invoked
581
596
  ,
582
- loadOptions: debounce(searchHiddenColumns, 300),
597
+ loadOptions: debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300),
583
598
  onInputChange: handleInputChange,
584
599
  components: selectInputComponents
585
600
  })), jsx(DroppablePanel$1, {
@@ -616,30 +631,29 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
616
631
  })
617
632
  });
618
633
  };
619
- ColumnSettingsManager.displayName = 'ColumnSettingsManager';
620
634
  ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
621
- availableColumns: PropTypes.arrayOf(PropTypes.shape({
622
- key: PropTypes.string.isRequired,
623
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
635
+ availableColumns: _pt.arrayOf(_pt.shape({
636
+ key: _pt.string.isRequired,
637
+ label: _pt.node.isRequired
624
638
  })).isRequired,
625
- selectedColumns: PropTypes.arrayOf(PropTypes.shape({
626
- key: PropTypes.string.isRequired,
627
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
639
+ selectedColumns: _pt.arrayOf(_pt.shape({
640
+ key: _pt.string.isRequired,
641
+ label: _pt.node.isRequired
628
642
  })).isRequired,
629
- onUpdateColumns: PropTypes.func.isRequired,
630
- areHiddenColumnsSearchable: PropTypes.bool,
631
- searchHiddenColumns: requiredIf(PropTypes.func, function (props) {
632
- return props.areHiddenColumnsSearchable;
633
- }),
634
- searchHiddenColumnsPlaceholder: PropTypes.string,
635
- onClose: PropTypes.func,
636
- primaryButton: PropTypes.element,
637
- secondaryButton: PropTypes.element,
638
- managerTheme: PropTypes.oneOf(['light', 'dark'])
643
+ onUpdateColumns: _pt.func.isRequired,
644
+ areHiddenColumnsSearchable: _pt.bool,
645
+ searchHiddenColumns: _pt.func,
646
+ searchHiddenColumnsPlaceholder: _pt.string,
647
+ onClose: _pt.func.isRequired,
648
+ primaryButton: _pt.element,
649
+ secondaryButton: _pt.element,
650
+ managerTheme: _pt.oneOf(['light', 'dark'])
639
651
  } : {};
640
- ColumnSettingsManager.defaultProps = {
652
+ ColumnSettingsManager.displayName = 'ColumnSettingsManager';
653
+ var defaultProps = {
641
654
  availableColumns: []
642
655
  };
656
+ ColumnSettingsManager.defaultProps = defaultProps;
643
657
  var ColumnSettingsManager$1 = ColumnSettingsManager;
644
658
 
645
659
  var messages = defineMessages({
@@ -666,17 +680,20 @@ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) {
666
680
 
667
681
  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)."; }
668
682
 
683
+ /* The horizontal constraint is set on this container instead of the SelectInput
684
+ because the input is always empty, and therefore doesn't take any space by itself
685
+ but we want to keep enough space for the placeholder to be readable */
669
686
  var SelectContainer = _styled("div", process.env.NODE_ENV === "production" ? {
670
- target: "eh8k7x01"
687
+ target: "e3i1gnv1"
671
688
  } : {
672
- target: "eh8k7x01",
689
+ target: "e3i1gnv1",
673
690
  label: "SelectContainer"
674
- })("width:", 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"]} */"));
691
+ })("width:", 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"]} */"));
675
692
 
676
693
  var TopBarContainer = _styled("div", process.env.NODE_ENV === "production" ? {
677
- target: "eh8k7x00"
694
+ target: "e3i1gnv0"
678
695
  } : {
679
- target: "eh8k7x00",
696
+ target: "e3i1gnv0",
680
697
  label: "TopBarContainer"
681
698
  })(process.env.NODE_ENV === "production" ? {
682
699
  name: "1ff36h2",
@@ -684,7 +701,7 @@ var TopBarContainer = _styled("div", process.env.NODE_ENV === "production" ? {
684
701
  } : {
685
702
  name: "1ff36h2",
686
703
  styles: "flex-grow:1",
687
- 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"]} */",
704
+ 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"]} */",
688
705
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
689
706
  });
690
707
 
@@ -716,6 +733,8 @@ var getSelectedColumns = function getSelectedColumns(mappedColumns) {
716
733
  };
717
734
 
718
735
  var DataTableSettings = function DataTableSettings(props) {
736
+ var _props$columnManager$, _props$columnManager;
737
+
719
738
  var areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
720
739
  var areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
721
740
  process.env.NODE_ENV !== "production" ? warning(areDisplaySettingsEnabled || areColumnSettingsEnabled ? typeof props.onSettingsChange === 'function' : true, "ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.") : void 0;
@@ -733,7 +752,7 @@ var DataTableSettings = function DataTableSettings(props) {
733
752
  });
734
753
 
735
754
  var handleDropdownChange = function handleDropdownChange(event) {
736
- return setOpenedPanelId(event.target.value);
755
+ return setOpenedPanelId(_Array$isArray(event.target.value) ? event.target.value[0] : event.target.value);
737
756
  };
738
757
 
739
758
  var mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
@@ -769,54 +788,60 @@ var DataTableSettings = function DataTableSettings(props) {
769
788
  }), openedPanelId === DISPLAY_SETTINGS && jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
770
789
  onClose: handleSettingsPanelChange,
771
790
  onDensityDisplayChange: function onDensityDisplayChange(event) {
772
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
791
+ var _props$onSettingsChan;
792
+
793
+ (_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);
773
794
  },
774
795
  onTextWrappingChange: function onTextWrappingChange(event) {
775
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
796
+ var _props$onSettingsChan2;
797
+
798
+ (_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);
776
799
  },
777
800
  managerTheme: props.managerTheme
778
801
  })), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager$1, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
779
- availableColumns: props.columnManager.hideableColumns,
802
+ availableColumns: (_props$columnManager$ = (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
780
803
  selectedColumns: selectedColumns,
781
804
  onClose: handleSettingsPanelChange,
782
805
  onUpdateColumns: function onUpdateColumns(nextVisibleColumns) {
806
+ var _props$onSettingsChan3;
807
+
783
808
  var keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, function (visibleColumn) {
784
809
  return visibleColumn.key;
785
810
  });
786
811
 
787
- props.onSettingsChange(UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
812
+ (_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 ? void 0 : _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
788
813
  },
789
814
  managerTheme: props.managerTheme
790
815
  }))]
791
816
  });
792
817
  };
793
818
 
794
- DataTableSettings.displayName = 'DataTableSettings';
795
819
  DataTableSettings.propTypes = process.env.NODE_ENV !== "production" ? {
796
- topBar: PropTypes.node,
797
- onSettingsChange: PropTypes.func,
798
- displaySettings: PropTypes.shape({
799
- disableDisplaySettings: PropTypes.bool,
800
- isCondensed: PropTypes.bool,
801
- isWrappingText: PropTypes.bool,
802
- primaryButton: PropTypes.element,
803
- secondaryButton: PropTypes.element
820
+ topBar: _pt.node,
821
+ onSettingsChange: _pt.func,
822
+ displaySettings: _pt.shape({
823
+ disableDisplaySettings: _pt.bool,
824
+ isCondensed: _pt.bool,
825
+ isWrappingText: _pt.bool,
826
+ primaryButton: _pt.element,
827
+ secondaryButton: _pt.element
804
828
  }),
805
- columnManager: PropTypes.shape({
806
- areHiddenColumnsSearchable: PropTypes.bool,
807
- disableColumnManager: PropTypes.bool,
808
- visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),
809
- hideableColumns: PropTypes.arrayOf(PropTypes.shape({
810
- key: PropTypes.string.isRequired,
811
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
829
+ columnManager: _pt.shape({
830
+ areHiddenColumnsSearchable: _pt.bool,
831
+ disableColumnManager: _pt.bool,
832
+ visibleColumnKeys: _pt.arrayOf(_pt.string).isRequired,
833
+ hideableColumns: _pt.arrayOf(_pt.shape({
834
+ key: _pt.string.isRequired,
835
+ label: _pt.node.isRequired
812
836
  })),
813
- searchHiddenColumns: PropTypes.func,
814
- searchHiddenColumnsPlaceholder: PropTypes.string,
815
- primaryButton: PropTypes.element,
816
- secondaryButton: PropTypes.element
837
+ searchHiddenColumns: _pt.func,
838
+ searchHiddenColumnsPlaceholder: _pt.string,
839
+ primaryButton: _pt.element,
840
+ secondaryButton: _pt.element
817
841
  }),
818
- managerTheme: PropTypes.oneOf(['light', 'dark'])
842
+ managerTheme: _pt.oneOf(['light', 'dark'])
819
843
  } : {};
844
+ DataTableSettings.displayName = 'DataTableSettings';
820
845
  var DataTableSettings$1 = DataTableSettings;
821
846
 
822
847
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
@@ -850,232 +875,28 @@ var DataTableManager = function DataTableManager(props) {
850
875
  };
851
876
 
852
877
  DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
853
- /**
854
- * Each object requires a unique `key` which should correspond to property key of
855
- * the items of `rows` that you want to render under this column, and a `label`
856
- * which defines the name shown on the header.
857
- * The list of columns to be rendered.
858
- * Each column can be customized (see properties below).
859
- */
860
- columns: PropTypes.arrayOf(PropTypes.shape({
861
- /**
862
- * The unique key of the column that is used to identify your data type.
863
- * You can use this value to determine which value from a row item should be rendered.
864
- * <br>
865
- * For example, if the data is a list of users, where each user has a `firstName` property,
866
- * the column key should be `firstName`, which renders the correct value by default.
867
- * The key can also be some custom or computed value, in which case you need to provide
868
- * an explicit mapping of the value by implementing either the `itemRendered` function or
869
- * the column-specific `renderItem` function.
870
- */
871
- key: PropTypes.string.isRequired,
872
-
873
- /**
874
- * The label of the column that will be shown on the column header.
875
- */
876
- label: PropTypes.node.isRequired,
877
-
878
- /**
879
- * Sets a width for this column. Accepts the same values as the ones specified for
880
- * individual [grid-template-columns](https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-columns).
881
- * <br>
882
- * For example, using `minmax` pairs (e.g. `minmax(200px, 400px)`), a combinations of
883
- * fraction values (`1fr`/`2fr`/etc), or fixed values such as `200px`.
884
- * By default, the column grows according to the content and respecting the total table available width.
885
- *
886
- * @@defaultValue@@: auto
887
- */
888
- width: PropTypes.string,
889
-
890
- /**
891
- * Use this to override the table's own `horizontalCellAlignment` prop for this specific column.
892
- */
893
- align: PropTypes.oneOf(['left', 'center', 'right']),
894
-
895
- /**
896
- * A callback function, called when the header cell is clicked.
897
- * <br>
898
- * Signature: `(event) => void`
899
- */
900
- onClick: PropTypes.func,
901
-
902
- /**
903
- * A callback function to render the content of cells under this column, overriding
904
- * the default `itemRenderer` prop of the table.
905
- * <br>
906
- * Signature: `(row: object, isRowCollapsed: boolean) => React.Node`
907
- */
908
- renderItem: PropTypes.func,
909
-
910
- /**
911
- * Use this prop to place an `Icon` or `IconButton` on the left of the column label.
912
- * It is advised to place these types of components through this prop instead of `label`,
913
- * in order to properly position and align the elements.
914
- * This is particularly useful for medium-sized icons which require more vertical space than the typography.
915
- */
916
- headerIcon: PropTypes.node,
917
-
918
- /**
919
- * Set this to `true` to allow text content of this cell to be truncated with an ellipsis,
920
- * instead of breaking into multiple lines.
921
- * <br>
922
- * NOTE: when using this option, it is recommended to specify a `width` for the column, because
923
- * if the table doesn't have enough space for all columns, it will start clipping the columns
924
- * with _truncated_ content, and if no `width` is set (or the value is set `auto` -- the default)
925
- * it can shrink until the column disappears completely.
926
- * By enforcing a minimum width for these columns, the table will respect them and grow horizontally,
927
- * adding scrollbars if needed.
928
- *
929
- * @@defaultValue@@: false
930
- */
931
- isTruncated: PropTypes.bool,
932
-
933
- /**
934
- * Set this to `true` to show a sorting button, which calls `onSortChange` upon being clicked.
935
- * You should enable this flag for every column you want to be able to sort.
936
- * When at least one column is sortable, the table props `sortBy`, `sortDirection` and `onSortChange` should be provided.
937
- *
938
- * @@defaultValue@@: false
939
- */
940
- isSortable: PropTypes.bool,
941
-
942
- /**
943
- * Set this to `true` to prevent this column from being manually resized by dragging
944
- * the edge of the header with a mouse.
945
- *
946
- * @@defaultValue@@: false
947
- */
948
- disableResizing: PropTypes.bool,
949
-
950
- /**
951
- * Set this to `true` to prevent click event propagation for this cell.
952
- * You might want this if you need the column to have its own call-to-action or input while
953
- * the row also has a defined `onRowClick`.
954
- *
955
- * @@defaultValue@@: false
956
- */
957
- shouldIgnoreRowClick: PropTypes.bool
878
+ columns: _pt.arrayOf(_pt.shape({
879
+ key: _pt.string.isRequired,
880
+ label: _pt.node.isRequired,
881
+ width: _pt.string,
882
+ align: _pt.oneOf(['left', 'center', 'right']),
883
+ onClick: _pt.func,
884
+ renderItem: _pt.func,
885
+ headerIcon: _pt.node,
886
+ isTruncated: _pt.bool,
887
+ isSortable: _pt.bool,
888
+ disableResizing: _pt.bool,
889
+ shouldIgnoreRowClick: _pt.bool
958
890
  })).isRequired,
959
-
960
- /**
961
- * Any React node. Usually you want to render the `<DataTable>` component.
962
- * <br>
963
- * Note that the child component will implicitly receive the props `columns` and `isCondensed` from the `<DataTableManager>`.
964
- */
965
- children: PropTypes.node.isRequired,
966
-
967
- /**
968
- * The managed display settings of the table.
969
- */
970
- displaySettings: PropTypes.shape({
971
- /**
972
- * Set this flag to `false` to show the display settings panel option.
973
- *
974
- * @@defaultValue@@: true
975
- */
976
- disableDisplaySettings: PropTypes.bool,
977
-
978
- /**
979
- * Set this to `true` to reduce the paddings of all cells, allowing the table to display
980
- * more data in less space.
981
- *
982
- * @@defaultValue@@: false
983
- */
984
- isCondensed: PropTypes.bool,
985
-
986
- /**
987
- * Set this to `true` to allow text in a cell to wrap.
988
- * <br>
989
- * This is required if `disableDisplaySettings` is set to `false`.
990
- *
991
- * @@defaultValue@@: false
992
- */
993
- isWrappingText: PropTypes.bool,
994
-
995
- /**
996
- * A React element to be rendered as the primary button, useful when the display settings work as a form.
997
- */
998
- primaryButton: PropTypes.element,
999
-
1000
- /**
1001
- * A React element to be rendered as the secondary button, useful when the display settings work as a form.
1002
- */
1003
- secondaryButton: PropTypes.element
1004
- }),
1005
-
1006
- /**
1007
- * The managed column settings of the table.
1008
- */
1009
- columnManager: PropTypes.shape({
1010
- /**
1011
- * Set this to `false` to show the column settings panel option.
1012
- *
1013
- * @@defaultValue@@: true
1014
- */
1015
- disableColumnManager: PropTypes.bool,
1016
-
1017
- /**
1018
- * The keys of the visible columns.
1019
- */
1020
- visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),
1021
-
1022
- /**
1023
- * The keys of the visible columns.
1024
- */
1025
- hideableColumns: PropTypes.arrayOf(PropTypes.shape({
1026
- key: PropTypes.string.isRequired,
1027
- label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
1028
- })),
1029
-
1030
- /**
1031
- * Set this to `true` to show a search input for the hidden columns panel.
1032
- */
1033
- areHiddenColumnsSearchable: PropTypes.bool,
1034
-
1035
- /**
1036
- * A callback function, called when the search input for the hidden columns panel changes.
1037
- * <br>
1038
- * Signature: `(event) => void`
1039
- */
1040
- searchHiddenColumns: PropTypes.func,
1041
-
1042
- /**
1043
- * Placeholder value of the search input for the hidden columns panel.
1044
- */
1045
- searchHiddenColumnsPlaceholder: PropTypes.string,
1046
-
1047
- /**
1048
- * A React element to be rendered as the primary button, useful when the column settings work as a form.
1049
- */
1050
- primaryButton: PropTypes.element,
1051
-
1052
- /**
1053
- * A React element to be rendered as the secondary button, useful when the column settings work as a form.
1054
- */
1055
- secondaryButton: PropTypes.element
1056
- }),
1057
-
1058
- /**
1059
- * A callback function, called when any of the properties of either display settings or column settings is modified.
1060
- * <br>
1061
- * Signature: `(action: string, nextValue: object) => void`
1062
- */
1063
- onSettingsChange: PropTypes.func,
1064
-
1065
- /**
1066
- * A React node for rendering additional information within the table manager.
1067
- */
1068
- topBar: PropTypes.node,
1069
-
1070
- /**
1071
- * Sets the background theme of the Card that contains the settings
1072
- */
1073
- managerTheme: PropTypes.oneOf(['light', 'dark'])
891
+ children: _pt.element.isRequired,
892
+ onSettingsChange: _pt.func,
893
+ topBar: _pt.node,
894
+ managerTheme: _pt.oneOf(['light', 'dark'])
1074
895
  } : {};
1075
896
  DataTableManager.displayName = 'DataTableManager';
1076
897
  var DataTableManager$1 = DataTableManager;
1077
898
 
1078
899
  // NOTE: This string will be replaced on build time with the package version.
1079
- var version = "13.0.3";
900
+ var version = "13.0.4";
1080
901
 
1081
902
  export { UPDATE_ACTIONS, DataTableManager$1 as default, version };