@commercetools-uikit/data-table-manager 19.20.0 → 19.21.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.
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.dev.js +2 -1
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.prod.js +2 -1
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.esm.js +2 -1
- package/dist/{column-settings-manager-95b43d72.esm.js → column-settings-manager-65bf0307.esm.js} +20 -19
- package/dist/{column-settings-manager-811cc2c0.cjs.dev.js → column-settings-manager-6ed9202b.cjs.dev.js} +20 -19
- package/dist/{column-settings-manager-8c0da2ae.cjs.prod.js → column-settings-manager-7634745b.cjs.prod.js} +17 -16
- package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +12 -10
- package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +12 -10
- package/dist/commercetools-uikit-data-table-manager.esm.js +13 -11
- package/dist/declarations/src/column-settings-manager/column-settings-manager.d.ts +1 -2
- package/dist/declarations/src/settings-container/settings-container.d.ts +1 -2
- package/package.json +23 -23
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var columnSettingsManager = require('../../dist/column-settings-manager-
|
|
5
|
+
var columnSettingsManager = require('../../dist/column-settings-manager-6ed9202b.cjs.dev.js');
|
|
6
6
|
require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
7
7
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
8
|
+
require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
8
9
|
require('@emotion/styled/base');
|
|
9
10
|
require('prop-types');
|
|
10
11
|
require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var columnSettingsManager = require('../../dist/column-settings-manager-
|
|
5
|
+
var columnSettingsManager = require('../../dist/column-settings-manager-7634745b.cjs.prod.js');
|
|
6
6
|
require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
7
7
|
require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
8
|
+
require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
8
9
|
require('@emotion/styled/base');
|
|
9
10
|
require('prop-types');
|
|
10
11
|
require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
export { C as ColumnSettingsManager } from '../../dist/column-settings-manager-
|
|
1
|
+
export { C as ColumnSettingsManager } from '../../dist/column-settings-manager-65bf0307.esm.js';
|
|
2
2
|
import '@babel/runtime-corejs3/helpers/defineProperty';
|
|
3
3
|
import '@babel/runtime-corejs3/helpers/slicedToArray';
|
|
4
|
+
import '@babel/runtime-corejs3/helpers/objectWithoutProperties';
|
|
4
5
|
import '@emotion/styled/base';
|
|
5
6
|
import 'prop-types';
|
|
6
7
|
import '@babel/runtime-corejs3/core-js-stable/promise';
|
package/dist/{column-settings-manager-95b43d72.esm.js → column-settings-manager-65bf0307.esm.js}
RENAMED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
2
2
|
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
3
|
+
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
3
4
|
import _styled from '@emotion/styled/base';
|
|
4
5
|
import _pt from 'prop-types';
|
|
5
6
|
import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
|
|
@@ -32,6 +33,7 @@ import Text from '@commercetools-uikit/text';
|
|
|
32
33
|
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
33
34
|
import Tag from '@commercetools-uikit/tag';
|
|
34
35
|
|
|
36
|
+
const _excluded$1 = ["containerTheme"];
|
|
35
37
|
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)."; }
|
|
36
38
|
const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
37
39
|
target: "e6ezr101"
|
|
@@ -44,7 +46,7 @@ const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
44
46
|
} : {
|
|
45
47
|
name: "1bhm8h2",
|
|
46
48
|
styles: "display:flex;flex:1;justify-content:space-between",
|
|
47
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/
|
|
49
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9ICh7XG4gIGNvbnRhaW5lclRoZW1lID0gJ2RhcmsnLFxuICAuLi5wcm9wc1xufTogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17Y29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
|
|
48
50
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
49
51
|
});
|
|
50
52
|
const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -52,18 +54,21 @@ const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
|
|
|
52
54
|
} : {
|
|
53
55
|
target: "e6ezr100",
|
|
54
56
|
label: "CardContentWrapper"
|
|
55
|
-
})("padding:", designTokens.spacing40, " ", designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/
|
|
56
|
-
const SettingsContainer =
|
|
57
|
+
})("padding:", designTokens.spacing40, " ", designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9ICh7XG4gIGNvbnRhaW5lclRoZW1lID0gJ2RhcmsnLFxuICAuLi5wcm9wc1xufTogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17Y29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */"));
|
|
58
|
+
const SettingsContainer = _ref => {
|
|
59
|
+
let _ref$containerTheme = _ref.containerTheme,
|
|
60
|
+
containerTheme = _ref$containerTheme === void 0 ? 'dark' : _ref$containerTheme,
|
|
61
|
+
props = _objectWithoutProperties(_ref, _excluded$1);
|
|
57
62
|
const intl = useIntl();
|
|
58
63
|
return jsx(CollapsibleMotion, {
|
|
59
64
|
isDefaultClosed: false,
|
|
60
|
-
children:
|
|
61
|
-
let registerContentNode =
|
|
62
|
-
containerStyles =
|
|
65
|
+
children: _ref2 => {
|
|
66
|
+
let registerContentNode = _ref2.registerContentNode,
|
|
67
|
+
containerStyles = _ref2.containerStyles;
|
|
63
68
|
return jsx(Card, {
|
|
64
69
|
type: "raised",
|
|
65
70
|
insetScale: "none",
|
|
66
|
-
theme:
|
|
71
|
+
theme: containerTheme,
|
|
67
72
|
children: jsx(CardContentWrapper, {
|
|
68
73
|
children: jsxs(Spacings.Stack, {
|
|
69
74
|
scale: "xl",
|
|
@@ -120,10 +125,6 @@ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
120
125
|
})])])
|
|
121
126
|
} : {};
|
|
122
127
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
123
|
-
const defaultProps$1 = {
|
|
124
|
-
containerTheme: 'dark'
|
|
125
|
-
};
|
|
126
|
-
SettingsContainer.defaultProps = defaultProps$1;
|
|
127
128
|
var SettingsContainer$1 = SettingsContainer;
|
|
128
129
|
|
|
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)."; }
|
|
@@ -292,6 +293,7 @@ var messages = defineMessages({
|
|
|
292
293
|
const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
293
294
|
const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
294
295
|
|
|
296
|
+
const _excluded = ["availableColumns"];
|
|
295
297
|
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; }
|
|
296
298
|
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; }
|
|
297
299
|
const noSearch = () => _Promise.resolve([]);
|
|
@@ -302,7 +304,7 @@ const DroppableContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
|
|
|
302
304
|
} : {
|
|
303
305
|
target: "en01od20",
|
|
304
306
|
label: "DroppableContainer"
|
|
305
|
-
})("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"]} */"));
|
|
307
|
+
})("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 = ({\n  availableColumns = [],\n  ...props\n}: 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        availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [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        availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, 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\nexport default ColumnSettingsManager;\n"]} */"));
|
|
306
308
|
const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
|
|
307
309
|
setIsDragging(false);
|
|
308
310
|
// Invalid drop destination, do nothing
|
|
@@ -342,7 +344,10 @@ const selectInputComponents = {
|
|
|
342
344
|
Menu: Nothing,
|
|
343
345
|
DropdownIndicator
|
|
344
346
|
};
|
|
345
|
-
const ColumnSettingsManager =
|
|
347
|
+
const ColumnSettingsManager = _ref => {
|
|
348
|
+
let _ref$availableColumns = _ref.availableColumns,
|
|
349
|
+
availableColumns = _ref$availableColumns === void 0 ? [] : _ref$availableColumns,
|
|
350
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
346
351
|
if (props.areHiddenColumnsSearchable) {
|
|
347
352
|
process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
|
|
348
353
|
}
|
|
@@ -355,8 +360,8 @@ const ColumnSettingsManager = props => {
|
|
|
355
360
|
const handleDragStart = () => {
|
|
356
361
|
setIsDragging(true);
|
|
357
362
|
};
|
|
358
|
-
const hiddenColumns = useMemo(() => differenceWith(
|
|
359
|
-
const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns,
|
|
363
|
+
const hiddenColumns = useMemo(() => differenceWith(availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [availableColumns, props.selectedColumns]);
|
|
364
|
+
const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, availableColumns]);
|
|
360
365
|
const debouncedSearchHiddenColumns = useMemo(() => debounce(searchHiddenColumns ?? noSearch, 300), [searchHiddenColumns]);
|
|
361
366
|
const handleInputChange = useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
362
367
|
return jsx(SettingsContainer$1, {
|
|
@@ -448,9 +453,5 @@ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
448
453
|
managerTheme: _pt.oneOf(['light', 'dark'])
|
|
449
454
|
} : {};
|
|
450
455
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
451
|
-
const defaultProps = {
|
|
452
|
-
availableColumns: []
|
|
453
|
-
};
|
|
454
|
-
ColumnSettingsManager.defaultProps = defaultProps;
|
|
455
456
|
|
|
456
457
|
export { ColumnSettingsManager as C, SettingsContainer$1 as S };
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
4
4
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
5
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
5
6
|
var _styled = require('@emotion/styled/base');
|
|
6
7
|
var _pt = require('prop-types');
|
|
7
8
|
var _Promise = require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -61,6 +62,7 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
|
61
62
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
62
63
|
var Tag__default = /*#__PURE__*/_interopDefault(Tag);
|
|
63
64
|
|
|
65
|
+
const _excluded$1 = ["containerTheme"];
|
|
64
66
|
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)."; }
|
|
65
67
|
const HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
66
68
|
target: "e6ezr101"
|
|
@@ -73,7 +75,7 @@ const HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.
|
|
|
73
75
|
} : {
|
|
74
76
|
name: "1bhm8h2",
|
|
75
77
|
styles: "display:flex;flex:1;justify-content:space-between",
|
|
76
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/
|
|
78
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9ICh7XG4gIGNvbnRhaW5lclRoZW1lID0gJ2RhcmsnLFxuICAuLi5wcm9wc1xufTogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17Y29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
|
|
77
79
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
78
80
|
});
|
|
79
81
|
const CardContentWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -81,18 +83,21 @@ const CardContentWrapper = /*#__PURE__*/_styled__default["default"]("div", proce
|
|
|
81
83
|
} : {
|
|
82
84
|
target: "e6ezr100",
|
|
83
85
|
label: "CardContentWrapper"
|
|
84
|
-
})("padding:", designSystem.designTokens.spacing40, " ", designSystem.designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/
|
|
85
|
-
const SettingsContainer =
|
|
86
|
+
})("padding:", designSystem.designTokens.spacing40, " ", designSystem.designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuZXhwb3J0IHR5cGUgVEludGxNZXNzYWdlID0gTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG59O1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZT86IFRJbnRsTWVzc2FnZTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG4gIGN1c3RvbVNldHRpbmdzVGl0bGU/OiBzdHJpbmcgfCBUSW50bE1lc3NhZ2U7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9ICh7XG4gIGNvbnRhaW5lclRoZW1lID0gJ2RhcmsnLFxuICAuLi5wcm9wc1xufTogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZCB0eXBlPVwicmFpc2VkXCIgaW5zZXRTY2FsZT1cIm5vbmVcIiB0aGVtZT17Y29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxDYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICAgIHtwcm9wcy5jdXN0b21TZXR0aW5nc1RpdGxlID8gKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiPlxuICAgICAgICAgICAgICAgICAgICB7cHJvcHMuY3VzdG9tU2V0dGluZ3NUaXRsZX1cbiAgICAgICAgICAgICAgICAgIDwvVGV4dC5IZWFkbGluZT5cbiAgICAgICAgICAgICAgICApIDogKFxuICAgICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmUgYXM9XCJoMlwiIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX0gLz5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */"));
|
|
87
|
+
const SettingsContainer = _ref => {
|
|
88
|
+
let _ref$containerTheme = _ref.containerTheme,
|
|
89
|
+
containerTheme = _ref$containerTheme === void 0 ? 'dark' : _ref$containerTheme,
|
|
90
|
+
props = _objectWithoutProperties(_ref, _excluded$1);
|
|
86
91
|
const intl = reactIntl.useIntl();
|
|
87
92
|
return jsxRuntime.jsx(CollapsibleMotion__default["default"], {
|
|
88
93
|
isDefaultClosed: false,
|
|
89
|
-
children:
|
|
90
|
-
let registerContentNode =
|
|
91
|
-
containerStyles =
|
|
94
|
+
children: _ref2 => {
|
|
95
|
+
let registerContentNode = _ref2.registerContentNode,
|
|
96
|
+
containerStyles = _ref2.containerStyles;
|
|
92
97
|
return jsxRuntime.jsx(Card__default["default"], {
|
|
93
98
|
type: "raised",
|
|
94
99
|
insetScale: "none",
|
|
95
|
-
theme:
|
|
100
|
+
theme: containerTheme,
|
|
96
101
|
children: jsxRuntime.jsx(CardContentWrapper, {
|
|
97
102
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
98
103
|
scale: "xl",
|
|
@@ -149,10 +154,6 @@ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
149
154
|
})])])
|
|
150
155
|
} : {};
|
|
151
156
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
152
|
-
const defaultProps$1 = {
|
|
153
|
-
containerTheme: 'dark'
|
|
154
|
-
};
|
|
155
|
-
SettingsContainer.defaultProps = defaultProps$1;
|
|
156
157
|
var SettingsContainer$1 = SettingsContainer;
|
|
157
158
|
|
|
158
159
|
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)."; }
|
|
@@ -321,6 +322,7 @@ var messages = reactIntl.defineMessages({
|
|
|
321
322
|
const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
322
323
|
const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
323
324
|
|
|
325
|
+
const _excluded = ["availableColumns"];
|
|
324
326
|
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
325
327
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
326
328
|
const noSearch = () => _Promise__default["default"].resolve([]);
|
|
@@ -331,7 +333,7 @@ const DroppableContainer = /*#__PURE__*/_styled__default["default"]("div", proce
|
|
|
331
333
|
} : {
|
|
332
334
|
target: "en01od20",
|
|
333
335
|
label: "DroppableContainer"
|
|
334
|
-
})("width:100%;position:relative;max-width:", designSystem.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"]} */"));
|
|
336
|
+
})("width:100%;position:relative;max-width:", designSystem.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 = ({\n  availableColumns = [],\n  ...props\n}: 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        availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [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        availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, 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\nexport default ColumnSettingsManager;\n"]} */"));
|
|
335
337
|
const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
|
|
336
338
|
setIsDragging(false);
|
|
337
339
|
// Invalid drop destination, do nothing
|
|
@@ -371,7 +373,10 @@ const selectInputComponents = {
|
|
|
371
373
|
Menu: Nothing,
|
|
372
374
|
DropdownIndicator
|
|
373
375
|
};
|
|
374
|
-
const ColumnSettingsManager =
|
|
376
|
+
const ColumnSettingsManager = _ref => {
|
|
377
|
+
let _ref$availableColumns = _ref.availableColumns,
|
|
378
|
+
availableColumns = _ref$availableColumns === void 0 ? [] : _ref$availableColumns,
|
|
379
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
375
380
|
if (props.areHiddenColumnsSearchable) {
|
|
376
381
|
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
|
|
377
382
|
}
|
|
@@ -384,8 +389,8 @@ const ColumnSettingsManager = props => {
|
|
|
384
389
|
const handleDragStart = () => {
|
|
385
390
|
setIsDragging(true);
|
|
386
391
|
};
|
|
387
|
-
const hiddenColumns = react.useMemo(() => differenceWith__default["default"](
|
|
388
|
-
const handleDragEnd = react.useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns,
|
|
392
|
+
const hiddenColumns = react.useMemo(() => differenceWith__default["default"](availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [availableColumns, props.selectedColumns]);
|
|
393
|
+
const handleDragEnd = react.useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, availableColumns]);
|
|
389
394
|
const debouncedSearchHiddenColumns = react.useMemo(() => debounce__default["default"](searchHiddenColumns ?? noSearch, 300), [searchHiddenColumns]);
|
|
390
395
|
const handleInputChange = react.useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
391
396
|
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
@@ -477,10 +482,6 @@ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
477
482
|
managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
|
|
478
483
|
} : {};
|
|
479
484
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
480
|
-
const defaultProps = {
|
|
481
|
-
availableColumns: []
|
|
482
|
-
};
|
|
483
|
-
ColumnSettingsManager.defaultProps = defaultProps;
|
|
484
485
|
|
|
485
486
|
exports.ColumnSettingsManager = ColumnSettingsManager;
|
|
486
487
|
exports.SettingsContainer = SettingsContainer$1;
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
4
4
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
5
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
5
6
|
var _styled = require('@emotion/styled/base');
|
|
6
7
|
require('prop-types');
|
|
7
8
|
var _Promise = require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -60,6 +61,7 @@ var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
|
60
61
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
61
62
|
var Tag__default = /*#__PURE__*/_interopDefault(Tag);
|
|
62
63
|
|
|
64
|
+
const _excluded$1 = ["containerTheme"];
|
|
63
65
|
const HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", {
|
|
64
66
|
target: "e6ezr101"
|
|
65
67
|
} )({
|
|
@@ -69,17 +71,20 @@ const HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", {
|
|
|
69
71
|
const CardContentWrapper = /*#__PURE__*/_styled__default["default"]("div", {
|
|
70
72
|
target: "e6ezr100"
|
|
71
73
|
} )("padding:", designSystem.designTokens.spacing40, " ", designSystem.designTokens.spacing50, ";" + ("" ));
|
|
72
|
-
const SettingsContainer =
|
|
74
|
+
const SettingsContainer = _ref => {
|
|
75
|
+
let _ref$containerTheme = _ref.containerTheme,
|
|
76
|
+
containerTheme = _ref$containerTheme === void 0 ? 'dark' : _ref$containerTheme,
|
|
77
|
+
props = _objectWithoutProperties(_ref, _excluded$1);
|
|
73
78
|
const intl = reactIntl.useIntl();
|
|
74
79
|
return jsxRuntime.jsx(CollapsibleMotion__default["default"], {
|
|
75
80
|
isDefaultClosed: false,
|
|
76
|
-
children:
|
|
77
|
-
let registerContentNode =
|
|
78
|
-
containerStyles =
|
|
81
|
+
children: _ref2 => {
|
|
82
|
+
let registerContentNode = _ref2.registerContentNode,
|
|
83
|
+
containerStyles = _ref2.containerStyles;
|
|
79
84
|
return jsxRuntime.jsx(Card__default["default"], {
|
|
80
85
|
type: "raised",
|
|
81
86
|
insetScale: "none",
|
|
82
|
-
theme:
|
|
87
|
+
theme: containerTheme,
|
|
83
88
|
children: jsxRuntime.jsx(CardContentWrapper, {
|
|
84
89
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
85
90
|
scale: "xl",
|
|
@@ -121,10 +126,6 @@ const SettingsContainer = props => {
|
|
|
121
126
|
};
|
|
122
127
|
SettingsContainer.propTypes = {};
|
|
123
128
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
124
|
-
const defaultProps$1 = {
|
|
125
|
-
containerTheme: 'dark'
|
|
126
|
-
};
|
|
127
|
-
SettingsContainer.defaultProps = defaultProps$1;
|
|
128
129
|
var SettingsContainer$1 = SettingsContainer;
|
|
129
130
|
|
|
130
131
|
const DraggingSmall = /*#__PURE__*/_styled__default["default"]("small", {
|
|
@@ -257,6 +258,7 @@ var messages = reactIntl.defineMessages({
|
|
|
257
258
|
const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
258
259
|
const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
259
260
|
|
|
261
|
+
const _excluded = ["availableColumns"];
|
|
260
262
|
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
261
263
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
262
264
|
const noSearch = () => _Promise__default["default"].resolve([]);
|
|
@@ -304,7 +306,10 @@ const selectInputComponents = {
|
|
|
304
306
|
Menu: Nothing,
|
|
305
307
|
DropdownIndicator
|
|
306
308
|
};
|
|
307
|
-
const ColumnSettingsManager =
|
|
309
|
+
const ColumnSettingsManager = _ref => {
|
|
310
|
+
let _ref$availableColumns = _ref.availableColumns,
|
|
311
|
+
availableColumns = _ref$availableColumns === void 0 ? [] : _ref$availableColumns,
|
|
312
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
308
313
|
if (props.areHiddenColumnsSearchable) ;
|
|
309
314
|
const intl = reactIntl.useIntl();
|
|
310
315
|
const _useState = react.useState(false),
|
|
@@ -315,8 +320,8 @@ const ColumnSettingsManager = props => {
|
|
|
315
320
|
const handleDragStart = () => {
|
|
316
321
|
setIsDragging(true);
|
|
317
322
|
};
|
|
318
|
-
const hiddenColumns = react.useMemo(() => differenceWith__default["default"](
|
|
319
|
-
const handleDragEnd = react.useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns,
|
|
323
|
+
const hiddenColumns = react.useMemo(() => differenceWith__default["default"](availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [availableColumns, props.selectedColumns]);
|
|
324
|
+
const handleDragEnd = react.useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, availableColumns]);
|
|
320
325
|
const debouncedSearchHiddenColumns = react.useMemo(() => debounce__default["default"](searchHiddenColumns ?? noSearch, 300), [searchHiddenColumns]);
|
|
321
326
|
const handleInputChange = react.useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
322
327
|
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
@@ -390,10 +395,6 @@ const ColumnSettingsManager = props => {
|
|
|
390
395
|
};
|
|
391
396
|
ColumnSettingsManager.propTypes = {};
|
|
392
397
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
393
|
-
const defaultProps = {
|
|
394
|
-
availableColumns: []
|
|
395
|
-
};
|
|
396
|
-
ColumnSettingsManager.defaultProps = defaultProps;
|
|
397
398
|
|
|
398
399
|
exports.ColumnSettingsManager = ColumnSettingsManager;
|
|
399
400
|
exports.SettingsContainer = SettingsContainer$1;
|
|
@@ -26,13 +26,14 @@ var icons = require('@commercetools-uikit/icons');
|
|
|
26
26
|
var DropdownMenu = require('@commercetools-uikit/dropdown-menu');
|
|
27
27
|
var IconButton = require('@commercetools-uikit/icon-button');
|
|
28
28
|
var Tooltip = require('@commercetools-uikit/tooltip');
|
|
29
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
29
30
|
var _pt = require('prop-types');
|
|
30
31
|
var FieldLabel = require('@commercetools-uikit/field-label');
|
|
31
32
|
var Grid = require('@commercetools-uikit/grid');
|
|
32
33
|
var RadioInput = require('@commercetools-uikit/radio-input');
|
|
33
34
|
var AccessibleHidden = require('@commercetools-uikit/accessible-hidden');
|
|
34
35
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
35
|
-
var columnSettingsManager = require('./column-settings-manager-
|
|
36
|
+
var columnSettingsManager = require('./column-settings-manager-6ed9202b.cjs.dev.js');
|
|
36
37
|
var hooks = require('@commercetools-uikit/hooks');
|
|
37
38
|
var dataTableManagerProvider = require('./data-table-manager-provider-fc238633.cjs.dev.js');
|
|
38
39
|
require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -130,10 +131,16 @@ const SHOW_HIDE_ON_DEMAND = 'show-hide-on-demand';
|
|
|
130
131
|
const DENSITY_COMFORTABLE = 'density-comfortable';
|
|
131
132
|
const DENSITY_COMPACT = 'density-compact';
|
|
132
133
|
|
|
133
|
-
const
|
|
134
|
+
const _excluded = ["isCondensed", "isWrappingText"];
|
|
135
|
+
const DensityManager = _ref => {
|
|
136
|
+
let _ref$isCondensed = _ref.isCondensed,
|
|
137
|
+
isCondensed = _ref$isCondensed === void 0 ? true : _ref$isCondensed,
|
|
138
|
+
_ref$isWrappingText = _ref.isWrappingText,
|
|
139
|
+
isWrappingText = _ref$isWrappingText === void 0 ? false : _ref$isWrappingText,
|
|
140
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
134
141
|
const intl = reactIntl.useIntl();
|
|
135
|
-
const textWrappingOption =
|
|
136
|
-
const densityDisplayOption =
|
|
142
|
+
const textWrappingOption = isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
143
|
+
const densityDisplayOption = isCondensed ? DENSITY_COMPACT : DENSITY_COMFORTABLE;
|
|
137
144
|
return jsxRuntime.jsx(columnSettingsManager.SettingsContainer, {
|
|
138
145
|
customSettingsTitle: props.title,
|
|
139
146
|
title: messages$2.title,
|
|
@@ -215,11 +222,6 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
215
222
|
managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
|
|
216
223
|
} : {};
|
|
217
224
|
DensityManager.displayName = 'DensityManager';
|
|
218
|
-
const defaultProps = {
|
|
219
|
-
isCondensed: true,
|
|
220
|
-
isWrappingText: false
|
|
221
|
-
};
|
|
222
|
-
DensityManager.defaultProps = defaultProps;
|
|
223
225
|
var DisplaySettingsManager = DensityManager;
|
|
224
226
|
|
|
225
227
|
var messages$1 = reactIntl.defineMessages({
|
|
@@ -495,7 +497,7 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
495
497
|
var DataTableManager$1 = DataTableManager;
|
|
496
498
|
|
|
497
499
|
// NOTE: This string will be replaced on build time with the package version.
|
|
498
|
-
var version = "19.
|
|
500
|
+
var version = "19.21.0";
|
|
499
501
|
|
|
500
502
|
exports.ColumnSettingsManager = columnSettingsManager.ColumnSettingsManager;
|
|
501
503
|
Object.defineProperty(exports, 'useRowSelection', {
|
|
@@ -26,13 +26,14 @@ var icons = require('@commercetools-uikit/icons');
|
|
|
26
26
|
var DropdownMenu = require('@commercetools-uikit/dropdown-menu');
|
|
27
27
|
var IconButton = require('@commercetools-uikit/icon-button');
|
|
28
28
|
var Tooltip = require('@commercetools-uikit/tooltip');
|
|
29
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
29
30
|
require('prop-types');
|
|
30
31
|
var FieldLabel = require('@commercetools-uikit/field-label');
|
|
31
32
|
var Grid = require('@commercetools-uikit/grid');
|
|
32
33
|
var RadioInput = require('@commercetools-uikit/radio-input');
|
|
33
34
|
var AccessibleHidden = require('@commercetools-uikit/accessible-hidden');
|
|
34
35
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
35
|
-
var columnSettingsManager = require('./column-settings-manager-
|
|
36
|
+
var columnSettingsManager = require('./column-settings-manager-7634745b.cjs.prod.js');
|
|
36
37
|
var hooks = require('@commercetools-uikit/hooks');
|
|
37
38
|
var dataTableManagerProvider = require('./data-table-manager-provider-c64c81aa.cjs.prod.js');
|
|
38
39
|
require('@babel/runtime-corejs3/core-js-stable/promise');
|
|
@@ -129,10 +130,16 @@ const SHOW_HIDE_ON_DEMAND = 'show-hide-on-demand';
|
|
|
129
130
|
const DENSITY_COMFORTABLE = 'density-comfortable';
|
|
130
131
|
const DENSITY_COMPACT = 'density-compact';
|
|
131
132
|
|
|
132
|
-
const
|
|
133
|
+
const _excluded = ["isCondensed", "isWrappingText"];
|
|
134
|
+
const DensityManager = _ref => {
|
|
135
|
+
let _ref$isCondensed = _ref.isCondensed,
|
|
136
|
+
isCondensed = _ref$isCondensed === void 0 ? true : _ref$isCondensed,
|
|
137
|
+
_ref$isWrappingText = _ref.isWrappingText,
|
|
138
|
+
isWrappingText = _ref$isWrappingText === void 0 ? false : _ref$isWrappingText,
|
|
139
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
133
140
|
const intl = reactIntl.useIntl();
|
|
134
|
-
const textWrappingOption =
|
|
135
|
-
const densityDisplayOption =
|
|
141
|
+
const textWrappingOption = isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
142
|
+
const densityDisplayOption = isCondensed ? DENSITY_COMPACT : DENSITY_COMFORTABLE;
|
|
136
143
|
return jsxRuntime.jsx(columnSettingsManager.SettingsContainer, {
|
|
137
144
|
customSettingsTitle: props.title,
|
|
138
145
|
title: messages$2.title,
|
|
@@ -204,11 +211,6 @@ const DensityManager = props => {
|
|
|
204
211
|
};
|
|
205
212
|
DensityManager.propTypes = {};
|
|
206
213
|
DensityManager.displayName = 'DensityManager';
|
|
207
|
-
const defaultProps = {
|
|
208
|
-
isCondensed: true,
|
|
209
|
-
isWrappingText: false
|
|
210
|
-
};
|
|
211
|
-
DensityManager.defaultProps = defaultProps;
|
|
212
214
|
var DisplaySettingsManager = DensityManager;
|
|
213
215
|
|
|
214
216
|
var messages$1 = reactIntl.defineMessages({
|
|
@@ -469,7 +471,7 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
469
471
|
var DataTableManager$1 = DataTableManager;
|
|
470
472
|
|
|
471
473
|
// NOTE: This string will be replaced on build time with the package version.
|
|
472
|
-
var version = "19.
|
|
474
|
+
var version = "19.21.0";
|
|
473
475
|
|
|
474
476
|
exports.ColumnSettingsManager = columnSettingsManager.ColumnSettingsManager;
|
|
475
477
|
Object.defineProperty(exports, 'useRowSelection', {
|
|
@@ -22,14 +22,15 @@ import { ColumnsIcon } from '@commercetools-uikit/icons';
|
|
|
22
22
|
import DropdownMenu from '@commercetools-uikit/dropdown-menu';
|
|
23
23
|
import IconButton from '@commercetools-uikit/icon-button';
|
|
24
24
|
import Tooltip from '@commercetools-uikit/tooltip';
|
|
25
|
+
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
25
26
|
import _pt from 'prop-types';
|
|
26
27
|
import FieldLabel from '@commercetools-uikit/field-label';
|
|
27
28
|
import Grid from '@commercetools-uikit/grid';
|
|
28
29
|
import RadioInput from '@commercetools-uikit/radio-input';
|
|
29
30
|
import AccessibleHidden from '@commercetools-uikit/accessible-hidden';
|
|
30
31
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
31
|
-
import { S as SettingsContainer, C as ColumnSettingsManager } from './column-settings-manager-
|
|
32
|
-
export { C as ColumnSettingsManager } from './column-settings-manager-
|
|
32
|
+
import { S as SettingsContainer, C as ColumnSettingsManager } from './column-settings-manager-65bf0307.esm.js';
|
|
33
|
+
export { C as ColumnSettingsManager } from './column-settings-manager-65bf0307.esm.js';
|
|
33
34
|
export { useRowSelection, useSorting } from '@commercetools-uikit/hooks';
|
|
34
35
|
export { D as DataTableManagerProvider, u as useDataTableManagerContext } from './data-table-manager-provider-32eb58dd.esm.js';
|
|
35
36
|
import '@babel/runtime-corejs3/core-js-stable/promise';
|
|
@@ -103,10 +104,16 @@ const SHOW_HIDE_ON_DEMAND = 'show-hide-on-demand';
|
|
|
103
104
|
const DENSITY_COMFORTABLE = 'density-comfortable';
|
|
104
105
|
const DENSITY_COMPACT = 'density-compact';
|
|
105
106
|
|
|
106
|
-
const
|
|
107
|
+
const _excluded = ["isCondensed", "isWrappingText"];
|
|
108
|
+
const DensityManager = _ref => {
|
|
109
|
+
let _ref$isCondensed = _ref.isCondensed,
|
|
110
|
+
isCondensed = _ref$isCondensed === void 0 ? true : _ref$isCondensed,
|
|
111
|
+
_ref$isWrappingText = _ref.isWrappingText,
|
|
112
|
+
isWrappingText = _ref$isWrappingText === void 0 ? false : _ref$isWrappingText,
|
|
113
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
107
114
|
const intl = useIntl();
|
|
108
|
-
const textWrappingOption =
|
|
109
|
-
const densityDisplayOption =
|
|
115
|
+
const textWrappingOption = isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
116
|
+
const densityDisplayOption = isCondensed ? DENSITY_COMPACT : DENSITY_COMFORTABLE;
|
|
110
117
|
return jsx(SettingsContainer, {
|
|
111
118
|
customSettingsTitle: props.title,
|
|
112
119
|
title: messages$2.title,
|
|
@@ -188,11 +195,6 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
188
195
|
managerTheme: _pt.oneOf(['light', 'dark'])
|
|
189
196
|
} : {};
|
|
190
197
|
DensityManager.displayName = 'DensityManager';
|
|
191
|
-
const defaultProps = {
|
|
192
|
-
isCondensed: true,
|
|
193
|
-
isWrappingText: false
|
|
194
|
-
};
|
|
195
|
-
DensityManager.defaultProps = defaultProps;
|
|
196
198
|
var DisplaySettingsManager = DensityManager;
|
|
197
199
|
|
|
198
200
|
var messages$1 = defineMessages({
|
|
@@ -468,6 +470,6 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
468
470
|
var DataTableManager$1 = DataTableManager;
|
|
469
471
|
|
|
470
472
|
// NOTE: This string will be replaced on build time with the package version.
|
|
471
|
-
var version = "19.
|
|
473
|
+
var version = "19.21.0";
|
|
472
474
|
|
|
473
475
|
export { UPDATE_ACTIONS, DataTableManager$1 as default, version };
|
|
@@ -19,8 +19,7 @@ export type TColumnSettingsManagerProps = {
|
|
|
19
19
|
};
|
|
20
20
|
export declare const handleColumnsUpdate: (dragResult: DropResult, onUpdateColumns: TColumnSettingsManagerProps["onUpdateColumns"], selectedColumns: TColumnSettingsManagerProps["selectedColumns"], availableColumns: TColumnSettingsManagerProps["availableColumns"], setIsDragging: Dispatch<boolean>) => void;
|
|
21
21
|
export declare const ColumnSettingsManager: {
|
|
22
|
-
(props: TColumnSettingsManagerProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
22
|
+
({ availableColumns, ...props }: TColumnSettingsManagerProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
23
23
|
displayName: string;
|
|
24
|
-
defaultProps: Pick<TColumnSettingsManagerProps, "availableColumns">;
|
|
25
24
|
};
|
|
26
25
|
export default ColumnSettingsManager;
|
|
@@ -16,8 +16,7 @@ type TSettingsContainerProps = {
|
|
|
16
16
|
customSettingsTitle?: string | TIntlMessage;
|
|
17
17
|
};
|
|
18
18
|
declare const SettingsContainer: {
|
|
19
|
-
(props: TSettingsContainerProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
19
|
+
({ containerTheme, ...props }: TSettingsContainerProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
20
20
|
displayName: string;
|
|
21
|
-
defaultProps: Pick<TSettingsContainerProps, "containerTheme">;
|
|
22
21
|
};
|
|
23
22
|
export default SettingsContainer;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/data-table-manager",
|
|
3
3
|
"description": "This component enhances the DataTable component and additionally provides a UI and state management to handle configuration of the table such as column manager.",
|
|
4
|
-
"version": "19.
|
|
4
|
+
"version": "19.21.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -28,28 +28,28 @@
|
|
|
28
28
|
"dependencies": {
|
|
29
29
|
"@babel/runtime": "^7.20.13",
|
|
30
30
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
31
|
-
"@commercetools-uikit/accessible-button": "19.
|
|
32
|
-
"@commercetools-uikit/accessible-hidden": "19.
|
|
33
|
-
"@commercetools-uikit/async-select-input": "19.
|
|
34
|
-
"@commercetools-uikit/card": "19.
|
|
35
|
-
"@commercetools-uikit/collapsible-motion": "19.
|
|
36
|
-
"@commercetools-uikit/design-system": "19.
|
|
37
|
-
"@commercetools-uikit/dropdown-menu": "19.
|
|
38
|
-
"@commercetools-uikit/field-label": "19.
|
|
39
|
-
"@commercetools-uikit/grid": "19.
|
|
40
|
-
"@commercetools-uikit/hooks": "19.
|
|
41
|
-
"@commercetools-uikit/icon-button": "19.
|
|
42
|
-
"@commercetools-uikit/icons": "19.
|
|
43
|
-
"@commercetools-uikit/primary-button": "19.
|
|
44
|
-
"@commercetools-uikit/radio-input": "19.
|
|
45
|
-
"@commercetools-uikit/secondary-button": "19.
|
|
46
|
-
"@commercetools-uikit/secondary-icon-button": "19.
|
|
47
|
-
"@commercetools-uikit/select-input": "19.
|
|
48
|
-
"@commercetools-uikit/spacings": "19.
|
|
49
|
-
"@commercetools-uikit/tag": "19.
|
|
50
|
-
"@commercetools-uikit/text": "19.
|
|
51
|
-
"@commercetools-uikit/tooltip": "19.
|
|
52
|
-
"@commercetools-uikit/utils": "19.
|
|
31
|
+
"@commercetools-uikit/accessible-button": "19.21.0",
|
|
32
|
+
"@commercetools-uikit/accessible-hidden": "19.21.0",
|
|
33
|
+
"@commercetools-uikit/async-select-input": "19.21.0",
|
|
34
|
+
"@commercetools-uikit/card": "19.21.0",
|
|
35
|
+
"@commercetools-uikit/collapsible-motion": "19.21.0",
|
|
36
|
+
"@commercetools-uikit/design-system": "19.21.0",
|
|
37
|
+
"@commercetools-uikit/dropdown-menu": "19.21.0",
|
|
38
|
+
"@commercetools-uikit/field-label": "19.21.0",
|
|
39
|
+
"@commercetools-uikit/grid": "19.21.0",
|
|
40
|
+
"@commercetools-uikit/hooks": "19.21.0",
|
|
41
|
+
"@commercetools-uikit/icon-button": "19.21.0",
|
|
42
|
+
"@commercetools-uikit/icons": "19.21.0",
|
|
43
|
+
"@commercetools-uikit/primary-button": "19.21.0",
|
|
44
|
+
"@commercetools-uikit/radio-input": "19.21.0",
|
|
45
|
+
"@commercetools-uikit/secondary-button": "19.21.0",
|
|
46
|
+
"@commercetools-uikit/secondary-icon-button": "19.21.0",
|
|
47
|
+
"@commercetools-uikit/select-input": "19.21.0",
|
|
48
|
+
"@commercetools-uikit/spacings": "19.21.0",
|
|
49
|
+
"@commercetools-uikit/tag": "19.21.0",
|
|
50
|
+
"@commercetools-uikit/text": "19.21.0",
|
|
51
|
+
"@commercetools-uikit/tooltip": "19.21.0",
|
|
52
|
+
"@commercetools-uikit/utils": "19.21.0",
|
|
53
53
|
"@emotion/react": "^11.10.5",
|
|
54
54
|
"@emotion/styled": "^11.10.5",
|
|
55
55
|
"@types/debounce-promise": "^3.1.6",
|