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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/README.md +50 -35
  2. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.d.ts +2 -0
  3. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.dev.js +43 -0
  4. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.js +7 -0
  5. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.prod.js +43 -0
  6. package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.esm.js +35 -0
  7. package/column-settings-manager/package.json +4 -0
  8. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.dev.js +6 -4
  9. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.prod.js +6 -4
  10. package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.esm.js +6 -4
  11. package/dist/column-settings-manager-1430ee4f.esm.js +463 -0
  12. package/dist/column-settings-manager-92b54563.cjs.dev.js +494 -0
  13. package/dist/column-settings-manager-b08669e8.cjs.prod.js +407 -0
  14. package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +142 -464
  15. package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +137 -383
  16. package/dist/commercetools-uikit-data-table-manager.esm.js +143 -454
  17. package/dist/{data-table-manager-provider-3f60b85b.esm.js → data-table-manager-provider-32eb58dd.esm.js} +41 -9
  18. package/dist/{data-table-manager-provider-6c690fc1.cjs.dev.js → data-table-manager-provider-c64c81aa.cjs.prod.js} +43 -10
  19. package/dist/{data-table-manager-provider-ddf7fb63.cjs.prod.js → data-table-manager-provider-fc238633.cjs.dev.js} +43 -10
  20. package/dist/declarations/src/column-settings-manager/column-settings-manager.d.ts +26 -0
  21. package/dist/declarations/src/column-settings-manager/export-types.d.ts +3 -0
  22. package/dist/declarations/src/column-settings-manager/index.d.ts +2 -0
  23. package/dist/declarations/src/constants.d.ts +2 -0
  24. package/dist/declarations/src/data-table-manager-provider/data-table-manager-provider.d.ts +11 -2
  25. package/dist/declarations/src/data-table-manager-provider/types.d.ts +62 -0
  26. package/dist/declarations/src/export-types.d.ts +2 -0
  27. package/dist/declarations/src/index.d.ts +1 -0
  28. package/dist/declarations/src/settings-container/index.d.ts +2 -0
  29. package/dist/declarations/src/settings-container/settings-container.d.ts +23 -0
  30. package/dist/declarations/src/types.d.ts +203 -2
  31. package/package.json +29 -25
@@ -0,0 +1,463 @@
1
+ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
2
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
3
+ import _styled from '@emotion/styled/base';
4
+ import _pt from 'prop-types';
5
+ import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
6
+ import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
7
+ import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
8
+ import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
9
+ import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
10
+ import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
11
+ import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
12
+ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
13
+ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
14
+ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
15
+ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
16
+ import { useState, useMemo, useCallback } from 'react';
17
+ import { useIntl, defineMessages } from 'react-intl';
18
+ import { Draggable, Droppable, DragDropContext } from 'react-beautiful-dnd';
19
+ import debounce from 'debounce-promise';
20
+ import differenceWith from 'lodash/differenceWith';
21
+ import { designTokens } from '@commercetools-uikit/design-system';
22
+ import AsyncSelectInput from '@commercetools-uikit/async-select-input';
23
+ import FieldLabel from '@commercetools-uikit/field-label';
24
+ import Spacings from '@commercetools-uikit/spacings';
25
+ import { CloseIcon, EyeCrossedIcon, EyeIcon, SearchIcon } from '@commercetools-uikit/icons';
26
+ import { warning } from '@commercetools-uikit/utils';
27
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
28
+ import AccessibleButton from '@commercetools-uikit/accessible-button';
29
+ import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
30
+ import Card from '@commercetools-uikit/card';
31
+ import Text from '@commercetools-uikit/text';
32
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
33
+ import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
34
+ import Tag from '@commercetools-uikit/tag';
35
+
36
+ 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)."; }
37
+ const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
38
+ target: "e6ezr101"
39
+ } : {
40
+ target: "e6ezr101",
41
+ label: "HeaderContainer"
42
+ })(process.env.NODE_ENV === "production" ? {
43
+ name: "1bhm8h2",
44
+ styles: "display:flex;flex:1;justify-content:space-between"
45
+ } : {
46
+ name: "1bhm8h2",
47
+ styles: "display:flex;flex:1;justify-content:space-between",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */",
49
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
50
+ });
51
+ const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
52
+ target: "e6ezr100"
53
+ } : {
54
+ target: "e6ezr100",
55
+ label: "CardContentWrapper"
56
+ })("padding:", designTokens.spacing40, " ", designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */"));
57
+ const SettingsContainer = props => {
58
+ const intl = useIntl();
59
+ return jsx(CollapsibleMotion, {
60
+ isDefaultClosed: false,
61
+ children: _ref => {
62
+ let registerContentNode = _ref.registerContentNode,
63
+ containerStyles = _ref.containerStyles;
64
+ return jsx(Card, {
65
+ type: "raised",
66
+ insetScale: "none",
67
+ theme: props.containerTheme,
68
+ children: jsx(CardContentWrapper, {
69
+ children: jsxs(Spacings.Stack, {
70
+ scale: "xl",
71
+ children: [jsxs(HeaderContainer, {
72
+ children: [props.customSettingsTitle ? jsx(Text.Headline, {
73
+ as: "h2",
74
+ children: props.customSettingsTitle
75
+ }) : jsx(Text.Headline, {
76
+ as: "h2",
77
+ intlMessage: props.title
78
+ }), jsx(AccessibleButton, {
79
+ onClick: props.onClose,
80
+ label: intl.formatMessage(props.closeButtonLabel),
81
+ children: jsx(CloseIcon, {
82
+ size: "medium"
83
+ })
84
+ })]
85
+ }), jsxs(Spacings.Stack, {
86
+ scale: "l",
87
+ children: [jsx(Spacings.Inset, {
88
+ scale: "s",
89
+ children: jsx("div", {
90
+ style: containerStyles,
91
+ children: jsx("div", {
92
+ ref: registerContentNode,
93
+ children: props.children
94
+ })
95
+ })
96
+ }), (props.secondaryButton || props.primaryButton) && jsxs(Spacings.Inline, {
97
+ justifyContent: "flex-end",
98
+ children: [props.secondaryButton, props.primaryButton]
99
+ })]
100
+ })]
101
+ })
102
+ })
103
+ });
104
+ }
105
+ });
106
+ };
107
+ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
108
+ title: _pt.oneOfType([_pt.any, _pt.shape({
109
+ values: _pt.objectOf(_pt.node)
110
+ })]),
111
+ closeButtonLabel: _pt.oneOfType([_pt.any, _pt.shape({
112
+ values: _pt.objectOf(_pt.node)
113
+ })]).isRequired,
114
+ onClose: _pt.func.isRequired,
115
+ primaryButton: _pt.element,
116
+ secondaryButton: _pt.element,
117
+ children: _pt.node.isRequired,
118
+ containerTheme: _pt.oneOf(['light', 'dark']),
119
+ customSettingsTitle: _pt.oneOfType([_pt.string, _pt.oneOfType([_pt.any, _pt.shape({
120
+ values: _pt.objectOf(_pt.node)
121
+ })])])
122
+ } : {};
123
+ SettingsContainer.displayName = 'SettingsContainer';
124
+ const defaultProps$1 = {
125
+ containerTheme: 'dark'
126
+ };
127
+ SettingsContainer.defaultProps = defaultProps$1;
128
+ var SettingsContainer$1 = SettingsContainer;
129
+
130
+ 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)."; }
131
+ const DraggingSmall = /*#__PURE__*/_styled("small", process.env.NODE_ENV === "production" ? {
132
+ target: "e1mp438g1"
133
+ } : {
134
+ target: "e1mp438g1",
135
+ label: "DraggingSmall"
136
+ })(process.env.NODE_ENV === "production" ? {
137
+ name: "1fhyj3b",
138
+ styles: "&:hover{cursor:grab;}"
139
+ } : {
140
+ name: "1fhyj3b",
141
+ styles: "&:hover{cursor:grab;}",
142
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFa0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */",
143
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
144
+ });
145
+ const DraggingContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
146
+ target: "e1mp438g0"
147
+ } : {
148
+ target: "e1mp438g0",
149
+ label: "DraggingContainer"
150
+ })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRb0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */"));
151
+ var DraggingContainer$1 = DraggingContainer;
152
+
153
+ function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
154
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
155
+ const DraggableTagWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
156
+ target: "emzjy4n0"
157
+ } : {
158
+ target: "emzjy4n0",
159
+ label: "DraggableTagWrapper"
160
+ })("padding:", designTokens.spacing10, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbmV4cG9ydCB0eXBlIFRDb2x1bW5EYXRhID0ge1xuICBrZXk6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFREcmFnZ2FibGVUYWdQcm9wcyA9IHtcbiAgY29sdW1uOiBUQ29sdW1uRGF0YTtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIG9uUmVtb3ZlPzogKGluZGV4OiBudW1iZXIpID0+IHZvaWQ7XG59O1xuXG5jb25zdCBEcmFnZ2FibGVUYWdXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfSAwO1xuYDtcblxuY29uc3QgRHJhZ2dhYmxlVGFnID0gKHByb3BzOiBURHJhZ2dhYmxlVGFnUHJvcHMpID0+IHtcbiAgY29uc3QgaGFuZGxlUmVtb3ZlQ29sdW1uID0gKCkgPT4gcHJvcHMub25SZW1vdmU/Lihwcm9wcy5pbmRleCk7XG5cbiAgcmV0dXJuIChcbiAgICA8RHJhZ2dhYmxlXG4gICAgICBkcmFnZ2FibGVJZD17cHJvcHMuY29sdW1uLmtleX1cbiAgICAgIGluZGV4PXtwcm9wcy5pbmRleH1cbiAgICAgIGlzRHJhZ0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgID5cbiAgICAgIHsocHJvdmlkZWQpID0+IHtcbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8RHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgICAgIDxEcmFnZ2luZ0NvbnRhaW5lclxuICAgICAgICAgICAgICByZWY9e3Byb3ZpZGVkLmlubmVyUmVmfVxuICAgICAgICAgICAgICB7Li4ucHJvdmlkZWQuZHJhZ2dhYmxlUHJvcHN9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnSGFuZGxlUHJvcHN9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUYWdcbiAgICAgICAgICAgICAgICBvblJlbW92ZT17cHJvcHMub25SZW1vdmUgPyBoYW5kbGVSZW1vdmVDb2x1bW4gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgICBpc0RyYWdnYWJsZVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3Byb3BzLmNvbHVtbi5sYWJlbH1cbiAgICAgICAgICAgICAgPC9UYWc+XG4gICAgICAgICAgICA8L0RyYWdnaW5nQ29udGFpbmVyPlxuICAgICAgICAgIDwvRHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgKTtcbiAgICAgIH19XG4gICAgPC9EcmFnZ2FibGU+XG4gICk7XG59O1xuXG5EcmFnZ2FibGVUYWcuZGlzcGxheU5hbWUgPSAnRHJhZ2dhYmxlVGFnJztcblxuZXhwb3J0IGRlZmF1bHQgRHJhZ2dhYmxlVGFnO1xuIl19 */"));
161
+ const DraggableTag = props => {
162
+ const handleRemoveColumn = () => {
163
+ var _props$onRemove;
164
+ return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
165
+ };
166
+ return jsx(Draggable, {
167
+ draggableId: props.column.key,
168
+ index: props.index,
169
+ isDragDisabled: props.isDisabled,
170
+ children: provided => {
171
+ return jsx(DraggableTagWrapper, {
172
+ children: jsx(DraggingContainer$1, _objectSpread$1(_objectSpread$1(_objectSpread$1({
173
+ ref: provided.innerRef
174
+ }, provided.draggableProps), provided.dragHandleProps), {}, {
175
+ children: jsx(Tag, {
176
+ onRemove: props.onRemove ? handleRemoveColumn : undefined,
177
+ isDisabled: props.isDisabled,
178
+ isDraggable: true,
179
+ children: props.column.label
180
+ })
181
+ }))
182
+ });
183
+ }
184
+ });
185
+ };
186
+ DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
187
+ column: _pt.shape({
188
+ key: _pt.string.isRequired,
189
+ label: _pt.node.isRequired
190
+ }).isRequired,
191
+ index: _pt.number.isRequired,
192
+ isDisabled: _pt.bool,
193
+ onRemove: _pt.func
194
+ } : {};
195
+ DraggableTag.displayName = 'DraggableTag';
196
+ var DraggableTag$1 = DraggableTag;
197
+
198
+ const TagContainerEditable = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
199
+ target: "e7rakq0"
200
+ } : {
201
+ target: "e7rakq0",
202
+ label: "TagContainerEditable"
203
+ })("background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";padding:", designTokens.spacing30, ";height:", designTokens.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
204
+ var TagContainerEditable$1 = TagContainerEditable;
205
+
206
+ var messages$1 = defineMessages({
207
+ loadMoreAttributesHint: {
208
+ id: 'UIKit.DataTableManager.ColumnManager.DroppablePanel.loadMoreAttributesHint',
209
+ description: 'Indicate that the user can use the search input to load more attributes',
210
+ defaultMessage: 'Load more attributes by using the search input above'
211
+ }
212
+ });
213
+
214
+ const DroppablePanel = props => {
215
+ return jsx(Droppable, {
216
+ droppableId: props.droppableId,
217
+ children: provided => {
218
+ var _context;
219
+ return jsxs(TagContainerEditable$1, {
220
+ "data-testid": props.droppableId,
221
+ ref: provided.innerRef,
222
+ children: [props.columns.length === 0 ? jsx(Spacings.Inset, {
223
+ scale: "s",
224
+ children: jsx(Text.Detail, {
225
+ tone: "secondary",
226
+ children: props.noColumnsText
227
+ })
228
+ }) : jsxs(Fragment, {
229
+ children: [_mapInstanceProperty(_context = props.columns).call(_context, (column, index) => {
230
+ var _context2;
231
+ return jsx(DraggableTag$1, {
232
+ column: column,
233
+ index: index,
234
+ onRemove: props.onRemove ? () => {
235
+ var _context3, _context4;
236
+ return props.onRemove([..._sliceInstanceProperty(_context3 = props.columns).call(_context3, 0, index), ..._sliceInstanceProperty(_context4 = props.columns).call(_context4, index + 1)]);
237
+ } : undefined,
238
+ isDisabled: props.isDisabled
239
+ }, _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index));
240
+ }), props.isSearchable && jsx(Spacings.Inset, {
241
+ scale: "xs",
242
+ children: jsx(Text.Detail, {
243
+ tone: "secondary",
244
+ intlMessage: messages$1.loadMoreAttributesHint
245
+ })
246
+ })]
247
+ }), provided.placeholder]
248
+ });
249
+ }
250
+ });
251
+ };
252
+ DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
253
+ droppableId: _pt.string.isRequired,
254
+ noColumnsText: _pt.node.isRequired,
255
+ columns: _pt.arrayOf(_pt.shape({
256
+ key: _pt.string.isRequired,
257
+ label: _pt.node.isRequired
258
+ })).isRequired,
259
+ isSearchable: _pt.bool,
260
+ isDisabled: _pt.bool,
261
+ onRemove: _pt.func
262
+ } : {};
263
+ DroppablePanel.displayName = 'DroppablePanel';
264
+ var DroppablePanel$1 = DroppablePanel;
265
+
266
+ var messages = defineMessages({
267
+ title: {
268
+ id: 'UIKit.DataTableManager.ColumnManager.title',
269
+ description: 'Title for the column manager component.',
270
+ defaultMessage: 'Column Manager'
271
+ },
272
+ visibleColumns: {
273
+ id: 'UIKit.DataTableManager.ColumnSelectorGroups.visible',
274
+ description: 'Message for the visible columns section.',
275
+ defaultMessage: 'Visible columns'
276
+ },
277
+ hiddenColumns: {
278
+ id: 'UIKit.DataTableManager.ColumnManager.hiddenColumns',
279
+ description: 'Message for the hidden columns section',
280
+ defaultMessage: 'Hidden columns'
281
+ },
282
+ noSelectedColumnsToShow: {
283
+ id: 'UIKit.DataTableManager.ColumnManager.noSelectedColumnsToShow',
284
+ description: 'Label when there are no selected columns to show',
285
+ defaultMessage: 'There are no selected columns to show.'
286
+ },
287
+ noHiddenColumnsToShow: {
288
+ id: 'UIKit.DataTableManager.ColumnManager.noHiddenColumnsToShow',
289
+ description: 'Label when there are no hidden columns to show',
290
+ defaultMessage: 'There are no hidden columns to show.'
291
+ },
292
+ closeButtonLabel: {
293
+ id: 'UIKit.DataTableManager.ColumnManager.closeButtonLabel',
294
+ description: 'Label for density manager close button.',
295
+ defaultMessage: 'Close'
296
+ }
297
+ });
298
+
299
+ const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
300
+ const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
301
+
302
+ function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
303
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
304
+ const noSearch = () => _Promise.resolve([]);
305
+ // 'onChange' prop in AsyncSelectInput is required but not needed here
306
+ const voidChangeHandler = () => undefined;
307
+ const DroppableContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
308
+ target: "en01od20"
309
+ } : {
310
+ target: "en01od20",
311
+ label: "DroppableContainer"
312
+ })("width:100%;position:relative;max-width:", designTokens.constraint10, ";cursor:", props => props.isDragging ? 'grabbing' : 'auto', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AAgE+D","file":"column-settings-manager.tsx","sourcesContent":["import {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\nexport type TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\nexport type TColumnSettingsManagerProps = {\n  title?: string;\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      customSettingsTitle={props.title}\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"l\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"big\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  onChange={voidChangeHandler}\n                  loadOptions={noSearch}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nconst defaultProps: Pick<TColumnSettingsManagerProps, 'availableColumns'> = {\n  availableColumns: [],\n};\nColumnSettingsManager.defaultProps = defaultProps;\n\nexport default ColumnSettingsManager;\n"]} */"));
313
+ const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
314
+ setIsDragging(false);
315
+ // Invalid drop destination, do nothing
316
+ if (!dragResult.destination) return;
317
+ if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {
318
+ if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
319
+ onUpdateColumns([..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)]);
320
+ } else {
321
+ // the destination is the selected columns panel
322
+
323
+ // it's a swap when the source and the destination are the same
324
+ const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
325
+ const items = isSwap ?
326
+ // remove the dragged item from its position if it is not coming from
327
+ // the hidden section (it is a swap)
328
+ [..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)] : selectedColumns;
329
+ const columns = isSwap ? selectedColumns : availableColumns;
330
+ const draggedColumn = _findInstanceProperty(columns).call(columns, col => col.key === dragResult.draggableId);
331
+
332
+ // push the column in the new position if draggedColumn is found
333
+ if (draggedColumn) {
334
+ onUpdateColumns([..._sliceInstanceProperty(items).call(items, 0, dragResult.destination.index), draggedColumn, ..._sliceInstanceProperty(items).call(items, dragResult.destination.index)]);
335
+ }
336
+ }
337
+ };
338
+ const DropdownIndicator = () => jsx(Spacings.Inline, {
339
+ alignItems: "center",
340
+ children: jsx(SearchIcon, {
341
+ size: "medium",
342
+ color: "primary"
343
+ })
344
+ });
345
+ DropdownIndicator.displayName = 'DropdownIndicator';
346
+ const Nothing = () => null;
347
+ const selectInputComponents = {
348
+ Option: Nothing,
349
+ Menu: Nothing,
350
+ DropdownIndicator
351
+ };
352
+ const ColumnSettingsManager = props => {
353
+ if (props.areHiddenColumnsSearchable) {
354
+ process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
355
+ }
356
+ const intl = useIntl();
357
+ const _useState = useState(false),
358
+ _useState2 = _slicedToArray(_useState, 2),
359
+ isDragging = _useState2[0],
360
+ setIsDragging = _useState2[1];
361
+ const searchHiddenColumns = props.searchHiddenColumns;
362
+ const handleDragStart = () => {
363
+ setIsDragging(true);
364
+ };
365
+ const hiddenColumns = useMemo(() => differenceWith(props.availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [props.availableColumns, props.selectedColumns]);
366
+ const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
367
+ const debouncedSearchHiddenColumns = useMemo(() => debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300), [searchHiddenColumns]);
368
+ const handleInputChange = useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
369
+ return jsx(SettingsContainer$1, {
370
+ customSettingsTitle: props.title,
371
+ title: messages.title,
372
+ closeButtonLabel: messages.closeButtonLabel,
373
+ onClose: props.onClose,
374
+ primaryButton: props.primaryButton,
375
+ secondaryButton: props.secondaryButton,
376
+ containerTheme: props.managerTheme,
377
+ children: jsx(DragDropContext, {
378
+ onDragEnd: handleDragEnd,
379
+ onDragStart: handleDragStart,
380
+ children: jsxs(Spacings.Inline, {
381
+ scale: "l",
382
+ children: [jsx(DroppableContainer, {
383
+ isDragging: isDragging,
384
+ "aria-labelledby": "hidden-columns",
385
+ children: jsxs(Spacings.Stack, {
386
+ scale: "m",
387
+ children: [jsxs(Spacings.Inline, {
388
+ scale: "s",
389
+ alignItems: "center",
390
+ children: [jsx(EyeCrossedIcon, {
391
+ size: "big"
392
+ }), jsx(FieldLabel, {
393
+ id: "hidden-columns",
394
+ title: intl.formatMessage(messages.hiddenColumns)
395
+ })]
396
+ }), props.areHiddenColumnsSearchable && jsx(AsyncSelectInput, _objectSpread(_objectSpread({}, props.searchHiddenColumnsPlaceholder ? {
397
+ placeholder: props.searchHiddenColumnsPlaceholder
398
+ } : undefined), {}, {
399
+ onChange: voidChangeHandler,
400
+ loadOptions: noSearch,
401
+ onInputChange: handleInputChange,
402
+ components: selectInputComponents
403
+ })), jsx(DroppablePanel$1, {
404
+ droppableId: HIDDEN_COLUMNS_PANEL,
405
+ "data-testid": HIDDEN_COLUMNS_PANEL,
406
+ noColumnsText: intl.formatMessage(messages.noHiddenColumnsToShow),
407
+ columns: hiddenColumns,
408
+ isSearchable: props.areHiddenColumnsSearchable
409
+ })]
410
+ })
411
+ }), jsx(DroppableContainer, {
412
+ isDragging: isDragging,
413
+ "aria-labelledby": "visible-columns",
414
+ children: jsxs(Spacings.Stack, {
415
+ scale: "m",
416
+ children: [jsxs(Spacings.Inline, {
417
+ scale: "xs",
418
+ alignItems: "center",
419
+ children: [jsx(EyeIcon, {
420
+ size: "medium"
421
+ }), jsx(FieldLabel, {
422
+ id: "visible-columns",
423
+ title: intl.formatMessage(messages.visibleColumns)
424
+ })]
425
+ }), jsx(DroppablePanel$1, {
426
+ droppableId: SELECTED_COLUMNS_PANEL,
427
+ "data-testid": SELECTED_COLUMNS_PANEL,
428
+ noColumnsText: intl.formatMessage(messages.noSelectedColumnsToShow),
429
+ columns: props.selectedColumns,
430
+ onRemove: props.onUpdateColumns
431
+ })]
432
+ })
433
+ })]
434
+ })
435
+ })
436
+ });
437
+ };
438
+ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
439
+ title: _pt.string,
440
+ availableColumns: _pt.arrayOf(_pt.shape({
441
+ key: _pt.string.isRequired,
442
+ label: _pt.node.isRequired
443
+ })).isRequired,
444
+ selectedColumns: _pt.arrayOf(_pt.shape({
445
+ key: _pt.string.isRequired,
446
+ label: _pt.node.isRequired
447
+ })).isRequired,
448
+ onUpdateColumns: _pt.func.isRequired,
449
+ areHiddenColumnsSearchable: _pt.bool,
450
+ searchHiddenColumns: _pt.func,
451
+ searchHiddenColumnsPlaceholder: _pt.string,
452
+ onClose: _pt.func.isRequired,
453
+ primaryButton: _pt.element,
454
+ secondaryButton: _pt.element,
455
+ managerTheme: _pt.oneOf(['light', 'dark'])
456
+ } : {};
457
+ ColumnSettingsManager.displayName = 'ColumnSettingsManager';
458
+ const defaultProps = {
459
+ availableColumns: []
460
+ };
461
+ ColumnSettingsManager.defaultProps = defaultProps;
462
+
463
+ export { ColumnSettingsManager as C, SettingsContainer$1 as S };