@commercetools-uikit/data-table-manager 15.7.0 → 15.9.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.
|
@@ -14,6 +14,7 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
|
|
|
14
14
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
15
15
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
16
16
|
var react = require('react');
|
|
17
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
17
18
|
var Spacings = require('@commercetools-uikit/spacings');
|
|
18
19
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
19
20
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
@@ -24,10 +25,9 @@ var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/ins
|
|
|
24
25
|
var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
|
|
25
26
|
var utils = require('@commercetools-uikit/utils');
|
|
26
27
|
var reactIntl = require('react-intl');
|
|
27
|
-
var
|
|
28
|
+
var AccessibleHidden = require('@commercetools-uikit/accessible-hidden');
|
|
28
29
|
var SelectInput = require('@commercetools-uikit/select-input');
|
|
29
30
|
var icons = require('@commercetools-uikit/icons');
|
|
30
|
-
var designSystem = require('@commercetools-uikit/design-system');
|
|
31
31
|
var FieldLabel = require('@commercetools-uikit/field-label');
|
|
32
32
|
var Grid = require('@commercetools-uikit/grid');
|
|
33
33
|
var RadioInput = require('@commercetools-uikit/radio-input');
|
|
@@ -62,7 +62,7 @@ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
|
62
62
|
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
63
63
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
64
64
|
var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
|
|
65
|
-
var
|
|
65
|
+
var AccessibleHidden__default = /*#__PURE__*/_interopDefault(AccessibleHidden);
|
|
66
66
|
var SelectInput__default = /*#__PURE__*/_interopDefault(SelectInput);
|
|
67
67
|
var FieldLabel__default = /*#__PURE__*/_interopDefault(FieldLabel);
|
|
68
68
|
var Grid__default = /*#__PURE__*/_interopDefault(Grid);
|
|
@@ -90,9 +90,9 @@ var DISPLAY_SETTINGS = 'displaySettings';
|
|
|
90
90
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
91
91
|
|
|
92
92
|
var HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
93
|
-
target: "
|
|
93
|
+
target: "e6ezr101"
|
|
94
94
|
} : {
|
|
95
|
-
target: "
|
|
95
|
+
target: "e6ezr101",
|
|
96
96
|
label: "HeaderContainer"
|
|
97
97
|
})(process.env.NODE_ENV === "production" ? {
|
|
98
98
|
name: "1bhm8h2",
|
|
@@ -100,49 +100,63 @@ var HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.en
|
|
|
100
100
|
} : {
|
|
101
101
|
name: "1bhm8h2",
|
|
102
102
|
styles: "display:flex;flex:1;justify-content:space-between",
|
|
103
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
103
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLy8gVE9ETzogQHJlZGVzaWduIGNsZWFudXBcbmltcG9ydCB0eXBlIHsgS2V5Ym9hcmRFdmVudCwgTW91c2VFdmVudCwgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCB0eXBlIE1lc3NhZ2VEZXNjcmlwdG9yIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgQ29sbGFwc2libGVNb3Rpb24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29sbGFwc2libGUtbW90aW9uJztcbmltcG9ydCBDYXJkIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NhcmQnO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgQ2xvc2VJY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zLCB1c2VUaGVtZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZTogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVGFibGVNYW5hZ2VyU2V0dGluZ3NQYW5lbH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcbiAgY29uc3QgeyB0aGVtZWRWYWx1ZSB9ID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZFxuICAgICAgICAgIHR5cGU9e3RoZW1lZFZhbHVlKCdmbGF0JywgJ3JhaXNlZCcpfVxuICAgICAgICAgIGluc2V0U2NhbGU9XCJub25lXCJcbiAgICAgICAgICB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPXt0aGVtZWRWYWx1ZSgneHMnLCAneGwnKX0+XG4gICAgICAgICAgICAgIDxIZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmVcbiAgICAgICAgICAgICAgICAgIGFzPXt0aGVtZWRWYWx1ZSgnaDMnLCAnaDInKX1cbiAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT17dGhlbWVkVmFsdWUoJ3hzJywgJ2wnKX0+XG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgPGRpdiBzdHlsZT17Y29udGFpbmVyU3R5bGVzfT5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5zZXQ+XG4gICAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5zZWNvbmRhcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgPC9DYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQaWNrPFRTZXR0aW5nc0NvbnRhaW5lclByb3BzLCAnY29udGFpbmVyVGhlbWUnPiA9IHtcbiAgY29udGFpbmVyVGhlbWU6ICdkYXJrJyxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBkZWZhdWx0IFNldHRpbmdzQ29udGFpbmVyO1xuIl19 */",
|
|
104
104
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
105
105
|
});
|
|
106
106
|
|
|
107
|
+
var CardContentWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
108
|
+
target: "e6ezr100"
|
|
109
|
+
} : {
|
|
110
|
+
target: "e6ezr100",
|
|
111
|
+
label: "CardContentWrapper"
|
|
112
|
+
})("padding:", designSystem.designTokens.paddingForTableManagerSettingsPanel, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLy8gVE9ETzogQHJlZGVzaWduIGNsZWFudXBcbmltcG9ydCB0eXBlIHsgS2V5Ym9hcmRFdmVudCwgTW91c2VFdmVudCwgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCB0eXBlIE1lc3NhZ2VEZXNjcmlwdG9yIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgQ29sbGFwc2libGVNb3Rpb24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29sbGFwc2libGUtbW90aW9uJztcbmltcG9ydCBDYXJkIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NhcmQnO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgQ2xvc2VJY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zLCB1c2VUaGVtZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZTogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVGFibGVNYW5hZ2VyU2V0dGluZ3NQYW5lbH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcbiAgY29uc3QgeyB0aGVtZWRWYWx1ZSB9ID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZFxuICAgICAgICAgIHR5cGU9e3RoZW1lZFZhbHVlKCdmbGF0JywgJ3JhaXNlZCcpfVxuICAgICAgICAgIGluc2V0U2NhbGU9XCJub25lXCJcbiAgICAgICAgICB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPXt0aGVtZWRWYWx1ZSgneHMnLCAneGwnKX0+XG4gICAgICAgICAgICAgIDxIZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmVcbiAgICAgICAgICAgICAgICAgIGFzPXt0aGVtZWRWYWx1ZSgnaDMnLCAnaDInKX1cbiAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT17dGhlbWVkVmFsdWUoJ3hzJywgJ2wnKX0+XG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgPGRpdiBzdHlsZT17Y29udGFpbmVyU3R5bGVzfT5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5zZXQ+XG4gICAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5zZWNvbmRhcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgPC9DYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQaWNrPFRTZXR0aW5nc0NvbnRhaW5lclByb3BzLCAnY29udGFpbmVyVGhlbWUnPiA9IHtcbiAgY29udGFpbmVyVGhlbWU6ICdkYXJrJyxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBkZWZhdWx0IFNldHRpbmdzQ29udGFpbmVyO1xuIl19 */"));
|
|
113
|
+
|
|
107
114
|
var SettingsContainer = function SettingsContainer(props) {
|
|
108
115
|
var intl = reactIntl.useIntl();
|
|
116
|
+
|
|
117
|
+
var _useTheme = designSystem.useTheme(),
|
|
118
|
+
themedValue = _useTheme.themedValue;
|
|
119
|
+
|
|
109
120
|
return jsxRuntime.jsx(CollapsibleMotion__default["default"], {
|
|
110
121
|
isDefaultClosed: false,
|
|
111
122
|
children: function children(_ref) {
|
|
112
123
|
var registerContentNode = _ref.registerContentNode,
|
|
113
124
|
containerStyles = _ref.containerStyles;
|
|
114
125
|
return jsxRuntime.jsx(Card__default["default"], {
|
|
115
|
-
type:
|
|
126
|
+
type: themedValue('flat', 'raised'),
|
|
127
|
+
insetScale: "none",
|
|
116
128
|
theme: props.containerTheme,
|
|
117
|
-
children: jsxRuntime.
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
children: [jsxRuntime.
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
style: containerStyles,
|
|
129
|
+
children: jsxRuntime.jsx(CardContentWrapper, {
|
|
130
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
131
|
+
scale: themedValue('xs', 'xl'),
|
|
132
|
+
children: [jsxRuntime.jsxs(HeaderContainer, {
|
|
133
|
+
children: [jsxRuntime.jsx(Text__default["default"].Headline, {
|
|
134
|
+
as: themedValue('h3', 'h2'),
|
|
135
|
+
intlMessage: props.title
|
|
136
|
+
}), jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
137
|
+
onClick: props.onClose,
|
|
138
|
+
label: intl.formatMessage(props.closeButtonLabel),
|
|
139
|
+
children: jsxRuntime.jsx(icons.CloseIcon, {
|
|
140
|
+
size: "medium"
|
|
141
|
+
})
|
|
142
|
+
})]
|
|
143
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
144
|
+
scale: themedValue('xs', 'l'),
|
|
145
|
+
children: [jsxRuntime.jsx(Spacings__default["default"].Inset, {
|
|
146
|
+
scale: "s",
|
|
136
147
|
children: jsxRuntime.jsx("div", {
|
|
137
|
-
|
|
138
|
-
children:
|
|
148
|
+
style: containerStyles,
|
|
149
|
+
children: jsxRuntime.jsx("div", {
|
|
150
|
+
ref: registerContentNode,
|
|
151
|
+
children: props.children
|
|
152
|
+
})
|
|
139
153
|
})
|
|
140
|
-
})
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
154
|
+
}), (props.secondaryButton || props.primaryButton) && jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
155
|
+
justifyContent: "flex-end",
|
|
156
|
+
children: [props.secondaryButton, props.primaryButton]
|
|
157
|
+
})]
|
|
144
158
|
})]
|
|
145
|
-
})
|
|
159
|
+
})
|
|
146
160
|
})
|
|
147
161
|
});
|
|
148
162
|
}
|
|
@@ -219,8 +233,13 @@ var DENSITY_COMPACT = 'density-compact';
|
|
|
219
233
|
|
|
220
234
|
var DensityManager = function DensityManager(props) {
|
|
221
235
|
var intl = reactIntl.useIntl();
|
|
236
|
+
|
|
237
|
+
var _useTheme = designSystem.useTheme(),
|
|
238
|
+
themedValue = _useTheme.themedValue;
|
|
239
|
+
|
|
222
240
|
var textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
223
241
|
var densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_DEFAULT;
|
|
242
|
+
var columnStackScale = themedValue('s', 'l');
|
|
224
243
|
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
225
244
|
title: messages$3.title,
|
|
226
245
|
closeButtonLabel: messages$3.closeButtonLabel,
|
|
@@ -233,10 +252,10 @@ var DensityManager = function DensityManager(props) {
|
|
|
233
252
|
gridTemplateColumns: "repeat(2, 1fr)",
|
|
234
253
|
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
235
254
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
236
|
-
scale:
|
|
255
|
+
scale: columnStackScale,
|
|
237
256
|
children: [jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
238
257
|
title: intl.formatMessage(messages$3.textWrappingSubtitle)
|
|
239
|
-
}), jsxRuntime.jsxs(
|
|
258
|
+
}), jsxRuntime.jsxs(AccessibleHidden__default["default"], {
|
|
240
259
|
children: [jsxRuntime.jsx("label", {
|
|
241
260
|
htmlFor: "text-wrapping-0",
|
|
242
261
|
children: "Select radio option: display full text"
|
|
@@ -260,10 +279,10 @@ var DensityManager = function DensityManager(props) {
|
|
|
260
279
|
})
|
|
261
280
|
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
262
281
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
263
|
-
scale:
|
|
282
|
+
scale: columnStackScale,
|
|
264
283
|
children: [jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
265
284
|
title: intl.formatMessage(messages$3.densityDisplaySubtitle)
|
|
266
|
-
}), jsxRuntime.jsxs(
|
|
285
|
+
}), jsxRuntime.jsxs(AccessibleHidden__default["default"], {
|
|
267
286
|
children: [jsxRuntime.jsx("label", {
|
|
268
287
|
htmlFor: "density-display-0",
|
|
269
288
|
children: "Select radio option: density default"
|
|
@@ -338,6 +357,13 @@ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys__default["d
|
|
|
338
357
|
|
|
339
358
|
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
340
359
|
|
|
360
|
+
var DraggableTagWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
361
|
+
target: "emzjy4n0"
|
|
362
|
+
} : {
|
|
363
|
+
target: "emzjy4n0",
|
|
364
|
+
label: "DraggableTagWrapper"
|
|
365
|
+
})("padding:", designSystem.designTokens.paddingForTableManagerDraggableTag, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbnR5cGUgVENvbHVtbkRhdGEgPSB7XG4gIGtleTogc3RyaW5nO1xuICBsYWJlbDogUmVhY3ROb2RlO1xufTtcblxudHlwZSBURHJhZ2dhYmxlVGFnUHJvcHMgPSB7XG4gIGNvbHVtbjogVENvbHVtbkRhdGE7XG4gIGluZGV4OiBudW1iZXI7XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBvblJlbW92ZT86IChpbmRleDogbnVtYmVyKSA9PiB2b2lkO1xufTtcblxuY29uc3QgRHJhZ2dhYmxlVGFnV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JUYWJsZU1hbmFnZXJEcmFnZ2FibGVUYWd9O1xuYDtcblxuY29uc3QgRHJhZ2dhYmxlVGFnID0gKHByb3BzOiBURHJhZ2dhYmxlVGFnUHJvcHMpID0+IHtcbiAgY29uc3QgaGFuZGxlUmVtb3ZlQ29sdW1uID0gKCkgPT4gcHJvcHMub25SZW1vdmU/Lihwcm9wcy5pbmRleCk7XG5cbiAgcmV0dXJuIChcbiAgICA8RHJhZ2dhYmxlXG4gICAgICBkcmFnZ2FibGVJZD17cHJvcHMuY29sdW1uLmtleX1cbiAgICAgIGluZGV4PXtwcm9wcy5pbmRleH1cbiAgICAgIGlzRHJhZ0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgID5cbiAgICAgIHsocHJvdmlkZWQpID0+IHtcbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8RHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgICAgIDxEcmFnZ2luZ0NvbnRhaW5lclxuICAgICAgICAgICAgICByZWY9e3Byb3ZpZGVkLmlubmVyUmVmfVxuICAgICAgICAgICAgICB7Li4ucHJvdmlkZWQuZHJhZ2dhYmxlUHJvcHN9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnSGFuZGxlUHJvcHN9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUYWdcbiAgICAgICAgICAgICAgICBvblJlbW92ZT17cHJvcHMub25SZW1vdmUgPyBoYW5kbGVSZW1vdmVDb2x1bW4gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgICBpc0RyYWdnYWJsZVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3Byb3BzLmNvbHVtbi5sYWJlbH1cbiAgICAgICAgICAgICAgPC9UYWc+XG4gICAgICAgICAgICA8L0RyYWdnaW5nQ29udGFpbmVyPlxuICAgICAgICAgIDwvRHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgKTtcbiAgICAgIH19XG4gICAgPC9EcmFnZ2FibGU+XG4gICk7XG59O1xuXG5EcmFnZ2FibGVUYWcuZGlzcGxheU5hbWUgPSAnRHJhZ2dhYmxlVGFnJztcblxuZXhwb3J0IGRlZmF1bHQgRHJhZ2dhYmxlVGFnO1xuIl19 */"));
|
|
366
|
+
|
|
341
367
|
var DraggableTag = function DraggableTag(props) {
|
|
342
368
|
var handleRemoveColumn = function handleRemoveColumn() {
|
|
343
369
|
var _props$onRemove;
|
|
@@ -350,21 +376,15 @@ var DraggableTag = function DraggableTag(props) {
|
|
|
350
376
|
index: props.index,
|
|
351
377
|
isDragDisabled: props.isDisabled,
|
|
352
378
|
children: function children(provided) {
|
|
353
|
-
return jsxRuntime.jsx(
|
|
354
|
-
scale: "xs",
|
|
379
|
+
return jsxRuntime.jsx(DraggableTagWrapper, {
|
|
355
380
|
children: jsxRuntime.jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
|
|
356
381
|
ref: provided.innerRef
|
|
357
382
|
}, provided.draggableProps), provided.dragHandleProps), {}, {
|
|
358
383
|
children: jsxRuntime.jsx(Tag__default["default"], {
|
|
359
384
|
onRemove: props.onRemove ? handleRemoveColumn : undefined,
|
|
360
385
|
isDisabled: props.isDisabled,
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
children: [jsxRuntime.jsx(icons.DragIcon, {
|
|
364
|
-
"data-testid": "drag-icon",
|
|
365
|
-
size: "medium"
|
|
366
|
-
}), props.column.label]
|
|
367
|
-
})
|
|
386
|
+
isDraggable: true,
|
|
387
|
+
children: props.column.label
|
|
368
388
|
})
|
|
369
389
|
}))
|
|
370
390
|
});
|
|
@@ -389,7 +409,7 @@ var TagContainerEditable = /*#__PURE__*/_styled__default["default"]("div", proce
|
|
|
389
409
|
} : {
|
|
390
410
|
target: "e7rakq0",
|
|
391
411
|
label: "TagContainerEditable"
|
|
392
|
-
})("background-color:", designSystem.designTokens.backgroundColorForInput, ";border:
|
|
412
|
+
})("background-color:", designSystem.designTokens.backgroundColorForInput, ";border:1px solid ", designSystem.designTokens.borderColorForTableManagerDroppableList, ";border-radius:", designSystem.designTokens.borderRadiusForTableManagerDroppableList, ";padding:", designSystem.designTokens.paddingForTableManagerDroppableList, ";height:", designSystem.designTokens.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0fTtcbiAgYm9yZGVyOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JUYWJsZU1hbmFnZXJEcm9wcGFibGVMaXN0fTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9yVGFibGVNYW5hZ2VyRHJvcHBhYmxlTGlzdH07XG4gIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JUYWJsZU1hbmFnZXJEcm9wcGFibGVMaXN0fTtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50N307XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuZXhwb3J0IGRlZmF1bHQgVGFnQ29udGFpbmVyRWRpdGFibGU7XG4iXX0= */"));
|
|
393
413
|
|
|
394
414
|
var TagContainerEditable$1 = TagContainerEditable;
|
|
395
415
|
|
|
@@ -513,7 +533,7 @@ var DroppableContainer = /*#__PURE__*/_styled__default["default"]("div", process
|
|
|
513
533
|
label: "DroppableContainer"
|
|
514
534
|
})("width:100%;position:relative;max-width:", designSystem.designTokens.constraint10, ";cursor:", function (props) {
|
|
515
535
|
return props.isDragging ? 'grabbing' : 'auto';
|
|
516
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AA+D+D","file":"column-settings-manager.tsx","sourcesContent":["import {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"m\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  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>\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"]} */"));
|
|
536
|
+
}, ";" + (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":["// TODO: @redesign cleanup\nimport {\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, useTheme } 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\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<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 { themedValue } = useTheme();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale={themedValue('m', 'l')}>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale={themedValue('s', 'm')}>\n              <Spacings.Inline\n                scale={themedValue('xs', 's')}\n                alignItems=\"center\"\n              >\n                <EyeCrossedIcon size={themedValue('medium', '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={themedValue('s', '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"]} */"));
|
|
517
537
|
|
|
518
538
|
var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) {
|
|
519
539
|
setIsDragging(false); // Invalid drop destination, do nothing
|
|
@@ -577,6 +597,9 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
|
|
|
577
597
|
|
|
578
598
|
var intl = reactIntl.useIntl();
|
|
579
599
|
|
|
600
|
+
var _useTheme = designSystem.useTheme(),
|
|
601
|
+
themedValue = _useTheme.themedValue;
|
|
602
|
+
|
|
580
603
|
var _useState = react.useState(false),
|
|
581
604
|
_useState2 = _slicedToArray(_useState, 2),
|
|
582
605
|
isDragging = _useState2[0],
|
|
@@ -613,16 +636,17 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
|
|
|
613
636
|
onDragEnd: handleDragEnd,
|
|
614
637
|
onDragStart: handleDragStart,
|
|
615
638
|
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
616
|
-
scale:
|
|
639
|
+
scale: themedValue('m', 'l'),
|
|
617
640
|
children: [jsxRuntime.jsx(DroppableContainer, {
|
|
618
641
|
isDragging: isDragging,
|
|
619
642
|
"aria-labelledby": "hidden-columns",
|
|
620
643
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
644
|
+
scale: themedValue('s', 'm'),
|
|
621
645
|
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
622
|
-
scale:
|
|
646
|
+
scale: themedValue('xs', 's'),
|
|
623
647
|
alignItems: "center",
|
|
624
648
|
children: [jsxRuntime.jsx(icons.EyeCrossedIcon, {
|
|
625
|
-
size:
|
|
649
|
+
size: themedValue('medium', 'big')
|
|
626
650
|
}), jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
627
651
|
id: "hidden-columns",
|
|
628
652
|
title: intl.formatMessage(messages$1.hiddenColumns)
|
|
@@ -646,6 +670,7 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
|
|
|
646
670
|
isDragging: isDragging,
|
|
647
671
|
"aria-labelledby": "visible-columns",
|
|
648
672
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
673
|
+
scale: themedValue('s', 'm'),
|
|
649
674
|
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
650
675
|
scale: "xs",
|
|
651
676
|
alignItems: "center",
|
|
@@ -725,7 +750,7 @@ var SelectContainer = /*#__PURE__*/_styled__default["default"]("div", process.en
|
|
|
725
750
|
} : {
|
|
726
751
|
target: "e3i1gnv1",
|
|
727
752
|
label: "SelectContainer"
|
|
728
|
-
})("min-width:", designSystem.designTokens.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AA8HkC","file":"data-table-settings.tsx","sourcesContent":["import { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  min-width: ${designTokens.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\n    );\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */"));
|
|
753
|
+
})("min-width:", designSystem.designTokens.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AA+HkC","file":"data-table-settings.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  min-width: ${designTokens.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const { themedValue } = useTheme();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\n    );\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale={themedValue('s', 'xs')}>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={\n                <TableIcon color={themedValue(undefined, 'neutral60')} />\n              }\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */"));
|
|
729
754
|
|
|
730
755
|
var TopBarContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
731
756
|
target: "e3i1gnv0"
|
|
@@ -738,7 +763,7 @@ var TopBarContainer = /*#__PURE__*/_styled__default["default"]("div", process.en
|
|
|
738
763
|
} : {
|
|
739
764
|
name: "1ff36h2",
|
|
740
765
|
styles: "flex-grow:1",
|
|
741
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAkIkC","file":"data-table-settings.tsx","sourcesContent":["import { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  min-width: ${designTokens.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\n    );\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
|
|
766
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAmIkC","file":"data-table-settings.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\ntype SelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  min-width: ${designTokens.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const { themedValue } = useTheme();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: SelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\n    );\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale={themedValue('s', 'xs')}>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={\n                <TableIcon color={themedValue(undefined, 'neutral60')} />\n              }\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
|
|
742
767
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
743
768
|
});
|
|
744
769
|
|
|
@@ -777,6 +802,9 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
777
802
|
process.env.NODE_ENV !== "production" ? utils.warning(areDisplaySettingsEnabled || areColumnSettingsEnabled ? typeof props.onSettingsChange === 'function' : true, "ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.") : void 0;
|
|
778
803
|
var intl = reactIntl.useIntl();
|
|
779
804
|
|
|
805
|
+
var _useTheme = designSystem.useTheme(),
|
|
806
|
+
themedValue = _useTheme.themedValue;
|
|
807
|
+
|
|
780
808
|
var _useState = react.useState(null),
|
|
781
809
|
_useState2 = _slicedToArray(_useState, 2),
|
|
782
810
|
openedPanelId = _useState2[0],
|
|
@@ -800,13 +828,14 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
800
828
|
};
|
|
801
829
|
|
|
802
830
|
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
831
|
+
scale: themedValue('s', 'xs'),
|
|
803
832
|
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
804
833
|
justifyContent: "space-between",
|
|
805
834
|
alignItems: "center",
|
|
806
835
|
children: [jsxRuntime.jsx(TopBarContainer, {
|
|
807
836
|
children: props.topBar
|
|
808
837
|
}), dropdownOptions.length > 0 && jsxRuntime.jsxs(SelectContainer, {
|
|
809
|
-
children: [jsxRuntime.jsx(
|
|
838
|
+
children: [jsxRuntime.jsx(AccessibleHidden__default["default"], {
|
|
810
839
|
children: jsxRuntime.jsx("label", {
|
|
811
840
|
htmlFor: "table-settings-dropdown",
|
|
812
841
|
children: "Open table manager dropdown"
|
|
@@ -819,7 +848,9 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
819
848
|
placeholder: intl.formatMessage(messages.placeholder),
|
|
820
849
|
onChange: handleDropdownChange,
|
|
821
850
|
options: dropdownOptions,
|
|
822
|
-
iconLeft: jsxRuntime.jsx(icons.TableIcon, {
|
|
851
|
+
iconLeft: jsxRuntime.jsx(icons.TableIcon, {
|
|
852
|
+
color: themedValue(undefined, 'neutral60')
|
|
853
|
+
})
|
|
823
854
|
})]
|
|
824
855
|
})]
|
|
825
856
|
}), openedPanelId === DISPLAY_SETTINGS && jsxRuntime.jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
|
|
@@ -886,6 +917,9 @@ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["def
|
|
|
886
917
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
887
918
|
|
|
888
919
|
var DataTableManager = function DataTableManager(props) {
|
|
920
|
+
var _useTheme = designSystem.useTheme(),
|
|
921
|
+
themedValue = _useTheme.themedValue;
|
|
922
|
+
|
|
889
923
|
var areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
890
924
|
var isWrappingText = areDisplaySettingsEnabled && props.displaySettings.isWrappingText;
|
|
891
925
|
var columns = react.useMemo(function () {
|
|
@@ -903,7 +937,7 @@ var DataTableManager = function DataTableManager(props) {
|
|
|
903
937
|
onSettingsChange: props.onSettingsChange,
|
|
904
938
|
columnManager: props.columnManager,
|
|
905
939
|
displaySettings: props.displaySettings,
|
|
906
|
-
managerTheme: props.managerTheme
|
|
940
|
+
managerTheme: themedValue(props.managerTheme, 'light')
|
|
907
941
|
}), /*#__PURE__*/react.cloneElement(props.children, {
|
|
908
942
|
columns: columns,
|
|
909
943
|
isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
|
|
@@ -934,7 +968,7 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
934
968
|
var DataTableManager$1 = DataTableManager;
|
|
935
969
|
|
|
936
970
|
// NOTE: This string will be replaced on build time with the package version.
|
|
937
|
-
var version = "15.
|
|
971
|
+
var version = "15.9.0";
|
|
938
972
|
|
|
939
973
|
Object.defineProperty(exports, 'useRowSelection', {
|
|
940
974
|
enumerable: true,
|