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