@commercetools-uikit/data-table-manager 15.15.0 → 15.15.1
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 +1 -0
- package/dist/commercetools-uikit-data-table-manager.cjs.d.ts.map +1 -0
- package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +127 -168
- package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +127 -168
- package/dist/commercetools-uikit-data-table-manager.esm.js +126 -167
- package/package.json +20 -20
|
@@ -14,9 +14,7 @@ import { designTokens, useTheme } from '@commercetools-uikit/design-system';
|
|
|
14
14
|
import Spacings from '@commercetools-uikit/spacings';
|
|
15
15
|
import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
|
|
16
16
|
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
17
|
-
import _toConsumableArray from '@babel/runtime-corejs3/helpers/esm/toConsumableArray';
|
|
18
17
|
import _styled from '@emotion/styled/base';
|
|
19
|
-
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
20
18
|
import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
21
19
|
import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
|
|
22
20
|
import { warning } from '@commercetools-uikit/utils';
|
|
@@ -38,20 +36,21 @@ import { Draggable, Droppable, DragDropContext } from 'react-beautiful-dnd';
|
|
|
38
36
|
import debounce from 'debounce-promise';
|
|
39
37
|
import differenceWith from 'lodash/differenceWith';
|
|
40
38
|
import AsyncSelectInput from '@commercetools-uikit/async-select-input';
|
|
39
|
+
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
41
40
|
import Tag from '@commercetools-uikit/tag';
|
|
42
41
|
export { useRowSelection, useSorting } from '@commercetools-uikit/hooks';
|
|
43
42
|
|
|
44
|
-
|
|
43
|
+
const UPDATE_ACTIONS = {
|
|
45
44
|
COLUMNS_UPDATE: 'columnsUpdate',
|
|
46
45
|
IS_TABLE_CONDENSED_UPDATE: 'isTableCondensedUpdate',
|
|
47
46
|
IS_TABLE_WRAPPING_TEXT_UPDATE: 'isTableWrappingTextUpdate'
|
|
48
47
|
};
|
|
49
|
-
|
|
50
|
-
|
|
48
|
+
const COLUMN_MANAGER = 'columnManager';
|
|
49
|
+
const DISPLAY_SETTINGS = 'displaySettings';
|
|
51
50
|
|
|
52
51
|
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)."; }
|
|
53
52
|
|
|
54
|
-
|
|
53
|
+
const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
55
54
|
target: "e6ezr101"
|
|
56
55
|
} : {
|
|
57
56
|
target: "e6ezr101",
|
|
@@ -66,23 +65,23 @@ var HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
|
|
|
66
65
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
67
66
|
});
|
|
68
67
|
|
|
69
|
-
|
|
68
|
+
const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
70
69
|
target: "e6ezr100"
|
|
71
70
|
} : {
|
|
72
71
|
target: "e6ezr100",
|
|
73
72
|
label: "CardContentWrapper"
|
|
74
73
|
})("padding:", designTokens.paddingForTableManagerSettingsPanel, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLy8gVE9ETzogQHJlZGVzaWduIGNsZWFudXBcbmltcG9ydCB0eXBlIHsgS2V5Ym9hcmRFdmVudCwgTW91c2VFdmVudCwgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCB0eXBlIE1lc3NhZ2VEZXNjcmlwdG9yIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgQ29sbGFwc2libGVNb3Rpb24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29sbGFwc2libGUtbW90aW9uJztcbmltcG9ydCBDYXJkIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NhcmQnO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgQ2xvc2VJY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zLCB1c2VUaGVtZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZTogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVGFibGVNYW5hZ2VyU2V0dGluZ3NQYW5lbH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcbiAgY29uc3QgeyB0aGVtZWRWYWx1ZSB9ID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZFxuICAgICAgICAgIHR5cGU9e3RoZW1lZFZhbHVlKCdmbGF0JywgJ3JhaXNlZCcpfVxuICAgICAgICAgIGluc2V0U2NhbGU9XCJub25lXCJcbiAgICAgICAgICB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPXt0aGVtZWRWYWx1ZSgneHMnLCAneGwnKX0+XG4gICAgICAgICAgICAgIDxIZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmVcbiAgICAgICAgICAgICAgICAgIGFzPXt0aGVtZWRWYWx1ZSgnaDMnLCAnaDInKX1cbiAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT17dGhlbWVkVmFsdWUoJ3hzJywgJ2wnKX0+XG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgPGRpdiBzdHlsZT17Y29udGFpbmVyU3R5bGVzfT5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5zZXQ+XG4gICAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5zZWNvbmRhcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgPC9DYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQaWNrPFRTZXR0aW5nc0NvbnRhaW5lclByb3BzLCAnY29udGFpbmVyVGhlbWUnPiA9IHtcbiAgY29udGFpbmVyVGhlbWU6ICdkYXJrJyxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBkZWZhdWx0IFNldHRpbmdzQ29udGFpbmVyO1xuIl19 */"));
|
|
75
74
|
|
|
76
|
-
|
|
77
|
-
|
|
75
|
+
const SettingsContainer = props => {
|
|
76
|
+
const intl = useIntl();
|
|
78
77
|
|
|
79
|
-
|
|
80
|
-
|
|
78
|
+
const _useTheme = useTheme(),
|
|
79
|
+
themedValue = _useTheme.themedValue;
|
|
81
80
|
|
|
82
81
|
return jsx(CollapsibleMotion, {
|
|
83
82
|
isDefaultClosed: false,
|
|
84
|
-
children:
|
|
85
|
-
|
|
83
|
+
children: _ref => {
|
|
84
|
+
let registerContentNode = _ref.registerContentNode,
|
|
86
85
|
containerStyles = _ref.containerStyles;
|
|
87
86
|
return jsx(Card, {
|
|
88
87
|
type: themedValue('flat', 'raised'),
|
|
@@ -139,7 +138,7 @@ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
139
138
|
containerTheme: _pt.oneOf(['light', 'dark'])
|
|
140
139
|
} : {};
|
|
141
140
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
142
|
-
|
|
141
|
+
const defaultProps$2 = {
|
|
143
142
|
containerTheme: 'dark'
|
|
144
143
|
};
|
|
145
144
|
SettingsContainer.defaultProps = defaultProps$2;
|
|
@@ -188,20 +187,20 @@ var messages$3 = defineMessages({
|
|
|
188
187
|
}
|
|
189
188
|
});
|
|
190
189
|
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
190
|
+
const WRAPPED_TEXT_VISIBLE = 'wrapped-text-visible';
|
|
191
|
+
const SHOW_HIDE_ON_DEMAND = 'show-hide-on-demand';
|
|
192
|
+
const DENSITY_DEFAULT = 'density-default';
|
|
193
|
+
const DENSITY_COMPACT = 'density-compact';
|
|
195
194
|
|
|
196
|
-
|
|
197
|
-
|
|
195
|
+
const DensityManager = props => {
|
|
196
|
+
const intl = useIntl();
|
|
198
197
|
|
|
199
|
-
|
|
200
|
-
|
|
198
|
+
const _useTheme = useTheme(),
|
|
199
|
+
themedValue = _useTheme.themedValue;
|
|
201
200
|
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
201
|
+
const textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
202
|
+
const densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_DEFAULT;
|
|
203
|
+
const columnStackScale = themedValue('s', 'l');
|
|
205
204
|
return jsx(SettingsContainer$1, {
|
|
206
205
|
title: messages$3.title,
|
|
207
206
|
closeButtonLabel: messages$3.closeButtonLabel,
|
|
@@ -282,7 +281,7 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
282
281
|
managerTheme: _pt.oneOf(['light', 'dark'])
|
|
283
282
|
} : {};
|
|
284
283
|
DensityManager.displayName = 'DensityManager';
|
|
285
|
-
|
|
284
|
+
const defaultProps$1 = {
|
|
286
285
|
isCondensed: false,
|
|
287
286
|
isWrappingText: false
|
|
288
287
|
};
|
|
@@ -291,7 +290,7 @@ var DisplaySettingsManager = DensityManager;
|
|
|
291
290
|
|
|
292
291
|
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)."; }
|
|
293
292
|
|
|
294
|
-
|
|
293
|
+
const DraggingSmall = /*#__PURE__*/_styled("small", process.env.NODE_ENV === "production" ? {
|
|
295
294
|
target: "e1mp438g1"
|
|
296
295
|
} : {
|
|
297
296
|
target: "e1mp438g1",
|
|
@@ -306,7 +305,7 @@ var DraggingSmall = /*#__PURE__*/_styled("small", process.env.NODE_ENV === "prod
|
|
|
306
305
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
307
306
|
});
|
|
308
307
|
|
|
309
|
-
|
|
308
|
+
const DraggingContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
310
309
|
target: "e1mp438g0"
|
|
311
310
|
} : {
|
|
312
311
|
target: "e1mp438g0",
|
|
@@ -319,15 +318,15 @@ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys(object); if
|
|
|
319
318
|
|
|
320
319
|
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$3(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
321
320
|
|
|
322
|
-
|
|
321
|
+
const DraggableTagWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
323
322
|
target: "emzjy4n0"
|
|
324
323
|
} : {
|
|
325
324
|
target: "emzjy4n0",
|
|
326
325
|
label: "DraggableTagWrapper"
|
|
327
326
|
})("padding:", designTokens.paddingForTableManagerDraggableTag, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbmV4cG9ydCB0eXBlIFRDb2x1bW5EYXRhID0ge1xuICBrZXk6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFREcmFnZ2FibGVUYWdQcm9wcyA9IHtcbiAgY29sdW1uOiBUQ29sdW1uRGF0YTtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIG9uUmVtb3ZlPzogKGluZGV4OiBudW1iZXIpID0+IHZvaWQ7XG59O1xuXG5jb25zdCBEcmFnZ2FibGVUYWdXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMucGFkZGluZ0ZvclRhYmxlTWFuYWdlckRyYWdnYWJsZVRhZ307XG5gO1xuXG5jb25zdCBEcmFnZ2FibGVUYWcgPSAocHJvcHM6IFREcmFnZ2FibGVUYWdQcm9wcykgPT4ge1xuICBjb25zdCBoYW5kbGVSZW1vdmVDb2x1bW4gPSAoKSA9PiBwcm9wcy5vblJlbW92ZT8uKHByb3BzLmluZGV4KTtcblxuICByZXR1cm4gKFxuICAgIDxEcmFnZ2FibGVcbiAgICAgIGRyYWdnYWJsZUlkPXtwcm9wcy5jb2x1bW4ua2V5fVxuICAgICAgaW5kZXg9e3Byb3BzLmluZGV4fVxuICAgICAgaXNEcmFnRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgPlxuICAgICAgeyhwcm92aWRlZCkgPT4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxEcmFnZ2FibGVUYWdXcmFwcGVyPlxuICAgICAgICAgICAgPERyYWdnaW5nQ29udGFpbmVyXG4gICAgICAgICAgICAgIHJlZj17cHJvdmlkZWQuaW5uZXJSZWZ9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnZ2FibGVQcm9wc31cbiAgICAgICAgICAgICAgey4uLnByb3ZpZGVkLmRyYWdIYW5kbGVQcm9wc31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPFRhZ1xuICAgICAgICAgICAgICAgIG9uUmVtb3ZlPXtwcm9wcy5vblJlbW92ZSA/IGhhbmRsZVJlbW92ZUNvbHVtbiA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgICAgIGlzRHJhZ2dhYmxlXG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7cHJvcHMuY29sdW1uLmxhYmVsfVxuICAgICAgICAgICAgICA8L1RhZz5cbiAgICAgICAgICAgIDwvRHJhZ2dpbmdDb250YWluZXI+XG4gICAgICAgICAgPC9EcmFnZ2FibGVUYWdXcmFwcGVyPlxuICAgICAgICApO1xuICAgICAgfX1cbiAgICA8L0RyYWdnYWJsZT5cbiAgKTtcbn07XG5cbkRyYWdnYWJsZVRhZy5kaXNwbGF5TmFtZSA9ICdEcmFnZ2FibGVUYWcnO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2FibGVUYWc7XG4iXX0= */"));
|
|
328
327
|
|
|
329
|
-
|
|
330
|
-
|
|
328
|
+
const DraggableTag = props => {
|
|
329
|
+
const handleRemoveColumn = () => {
|
|
331
330
|
var _props$onRemove;
|
|
332
331
|
|
|
333
332
|
return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
|
|
@@ -337,7 +336,7 @@ var DraggableTag = function DraggableTag(props) {
|
|
|
337
336
|
draggableId: props.column.key,
|
|
338
337
|
index: props.index,
|
|
339
338
|
isDragDisabled: props.isDisabled,
|
|
340
|
-
children:
|
|
339
|
+
children: provided => {
|
|
341
340
|
return jsx(DraggableTagWrapper, {
|
|
342
341
|
children: jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
|
|
343
342
|
ref: provided.innerRef
|
|
@@ -366,7 +365,7 @@ DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
366
365
|
DraggableTag.displayName = 'DraggableTag';
|
|
367
366
|
var DraggableTag$1 = DraggableTag;
|
|
368
367
|
|
|
369
|
-
|
|
368
|
+
const TagContainerEditable = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
370
369
|
target: "e7rakq0"
|
|
371
370
|
} : {
|
|
372
371
|
target: "e7rakq0",
|
|
@@ -383,10 +382,10 @@ var messages$2 = defineMessages({
|
|
|
383
382
|
}
|
|
384
383
|
});
|
|
385
384
|
|
|
386
|
-
|
|
385
|
+
const DroppablePanel = props => {
|
|
387
386
|
return jsx(Droppable, {
|
|
388
387
|
droppableId: props.droppableId,
|
|
389
|
-
children:
|
|
388
|
+
children: provided => {
|
|
390
389
|
var _context;
|
|
391
390
|
|
|
392
391
|
return jsxs(TagContainerEditable$1, {
|
|
@@ -399,16 +398,16 @@ var DroppablePanel = function DroppablePanel(props) {
|
|
|
399
398
|
children: props.noColumnsText
|
|
400
399
|
})
|
|
401
400
|
}) : jsxs(Fragment, {
|
|
402
|
-
children: [_mapInstanceProperty(_context = props.columns).call(_context,
|
|
401
|
+
children: [_mapInstanceProperty(_context = props.columns).call(_context, (column, index) => {
|
|
403
402
|
var _context2;
|
|
404
403
|
|
|
405
404
|
return jsx(DraggableTag$1, {
|
|
406
405
|
column: column,
|
|
407
406
|
index: index,
|
|
408
|
-
onRemove: props.onRemove ?
|
|
409
|
-
var _context3, _context4
|
|
407
|
+
onRemove: props.onRemove ? () => {
|
|
408
|
+
var _context3, _context4;
|
|
410
409
|
|
|
411
|
-
return props.onRemove(
|
|
410
|
+
return props.onRemove([..._sliceInstanceProperty(_context3 = props.columns).call(_context3, 0, index), ..._sliceInstanceProperty(_context4 = props.columns).call(_context4, index + 1)]);
|
|
412
411
|
} : undefined,
|
|
413
412
|
isDisabled: props.isDisabled
|
|
414
413
|
}, _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index));
|
|
@@ -472,121 +471,93 @@ var messages$1 = defineMessages({
|
|
|
472
471
|
}
|
|
473
472
|
});
|
|
474
473
|
|
|
475
|
-
|
|
476
|
-
|
|
474
|
+
const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
475
|
+
const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
477
476
|
|
|
478
477
|
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
479
478
|
|
|
480
|
-
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
479
|
+
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
481
480
|
|
|
482
|
-
|
|
483
|
-
return _Promise.resolve([]);
|
|
484
|
-
}; // 'onChange' prop in AsyncSelectInput is required but not needed here
|
|
481
|
+
const noSearch = () => _Promise.resolve([]); // 'onChange' prop in AsyncSelectInput is required but not needed here
|
|
485
482
|
|
|
486
483
|
|
|
487
|
-
|
|
488
|
-
return undefined;
|
|
489
|
-
};
|
|
484
|
+
const voidChangeHandler = () => undefined;
|
|
490
485
|
|
|
491
|
-
|
|
486
|
+
const DroppableContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
492
487
|
target: "en01od20"
|
|
493
488
|
} : {
|
|
494
489
|
target: "en01od20",
|
|
495
490
|
label: "DroppableContainer"
|
|
496
|
-
})("width:100%;position:relative;max-width:", designTokens.constraint10, ";cursor:", function (props) {
|
|
497
|
-
return props.isDragging ? 'grabbing' : 'auto';
|
|
498
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AAgE+D","file":"column-settings-manager.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\nexport type TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\nexport type TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const { themedValue } = useTheme();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale={themedValue('m', 'l')}>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale={themedValue('s', 'm')}>\n              <Spacings.Inline\n                scale={themedValue('xs', 's')}\n                alignItems=\"center\"\n              >\n                <EyeCrossedIcon size={themedValue('medium', 'big')} />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  onChange={voidChangeHandler}\n                  loadOptions={noSearch}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack scale={themedValue('s', 'm')}>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nconst defaultProps: Pick<TColumnSettingsManagerProps, 'availableColumns'> = {\n  availableColumns: [],\n};\nColumnSettingsManager.defaultProps = defaultProps;\n\nexport default ColumnSettingsManager;\n"]} */"));
|
|
491
|
+
})("width:100%;position:relative;max-width:", designTokens.constraint10, ";cursor:", props => props.isDragging ? 'grabbing' : 'auto', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AAgE+D","file":"column-settings-manager.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\nexport type TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\nexport type TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const { themedValue } = useTheme();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale={themedValue('m', 'l')}>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale={themedValue('s', 'm')}>\n              <Spacings.Inline\n                scale={themedValue('xs', 's')}\n                alignItems=\"center\"\n              >\n                <EyeCrossedIcon size={themedValue('medium', 'big')} />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  onChange={voidChangeHandler}\n                  loadOptions={noSearch}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack scale={themedValue('s', 'm')}>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nconst defaultProps: Pick<TColumnSettingsManagerProps, 'availableColumns'> = {\n  availableColumns: [],\n};\nColumnSettingsManager.defaultProps = defaultProps;\n\nexport default ColumnSettingsManager;\n"]} */"));
|
|
499
492
|
|
|
500
|
-
|
|
493
|
+
const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
|
|
501
494
|
setIsDragging(false); // Invalid drop destination, do nothing
|
|
502
495
|
|
|
503
496
|
if (!dragResult.destination) return;
|
|
504
497
|
|
|
505
498
|
if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {
|
|
506
|
-
var _context;
|
|
507
|
-
|
|
508
499
|
if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
|
|
509
|
-
onUpdateColumns(
|
|
500
|
+
onUpdateColumns([..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)]);
|
|
510
501
|
} else {
|
|
511
|
-
var _context2;
|
|
512
|
-
|
|
513
502
|
// the destination is the selected columns panel
|
|
514
503
|
// it's a swap when the source and the destination are the same
|
|
515
|
-
|
|
516
|
-
|
|
504
|
+
const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
|
|
505
|
+
const items = isSwap ? // remove the dragged item from its position if it is not coming from
|
|
517
506
|
// the hidden section (it is a swap)
|
|
518
|
-
|
|
519
|
-
|
|
507
|
+
[..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)] : selectedColumns;
|
|
508
|
+
const columns = isSwap ? selectedColumns : availableColumns;
|
|
520
509
|
|
|
521
|
-
|
|
522
|
-
return col.key === dragResult.draggableId;
|
|
523
|
-
}); // push the column in the new position if draggedColumn is found
|
|
510
|
+
const draggedColumn = _findInstanceProperty(columns).call(columns, col => col.key === dragResult.draggableId); // push the column in the new position if draggedColumn is found
|
|
524
511
|
|
|
525
512
|
|
|
526
513
|
if (draggedColumn) {
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
onUpdateColumns(_concatInstanceProperty(_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty(items).call(items, 0, dragResult.destination.index)), [draggedColumn], _toConsumableArray(_sliceInstanceProperty(items).call(items, dragResult.destination.index))));
|
|
514
|
+
onUpdateColumns([..._sliceInstanceProperty(items).call(items, 0, dragResult.destination.index), draggedColumn, ..._sliceInstanceProperty(items).call(items, dragResult.destination.index)]);
|
|
530
515
|
}
|
|
531
516
|
}
|
|
532
517
|
};
|
|
533
518
|
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
});
|
|
542
|
-
};
|
|
519
|
+
const DropdownIndicator = () => jsx(Spacings.Inline, {
|
|
520
|
+
alignItems: "center",
|
|
521
|
+
children: jsx(SearchIcon, {
|
|
522
|
+
size: "medium",
|
|
523
|
+
color: "primary"
|
|
524
|
+
})
|
|
525
|
+
});
|
|
543
526
|
|
|
544
527
|
DropdownIndicator.displayName = 'DropdownIndicator';
|
|
545
528
|
|
|
546
|
-
|
|
547
|
-
return null;
|
|
548
|
-
};
|
|
529
|
+
const Nothing = () => null;
|
|
549
530
|
|
|
550
|
-
|
|
531
|
+
const selectInputComponents = {
|
|
551
532
|
Option: Nothing,
|
|
552
533
|
Menu: Nothing,
|
|
553
|
-
DropdownIndicator
|
|
534
|
+
DropdownIndicator
|
|
554
535
|
};
|
|
555
|
-
|
|
536
|
+
const ColumnSettingsManager = props => {
|
|
556
537
|
if (props.areHiddenColumnsSearchable) {
|
|
557
538
|
process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
|
|
558
539
|
}
|
|
559
540
|
|
|
560
|
-
|
|
541
|
+
const intl = useIntl();
|
|
561
542
|
|
|
562
|
-
|
|
563
|
-
|
|
543
|
+
const _useTheme = useTheme(),
|
|
544
|
+
themedValue = _useTheme.themedValue;
|
|
564
545
|
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
546
|
+
const _useState = useState(false),
|
|
547
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
548
|
+
isDragging = _useState2[0],
|
|
549
|
+
setIsDragging = _useState2[1];
|
|
569
550
|
|
|
570
|
-
|
|
551
|
+
const searchHiddenColumns = props.searchHiddenColumns;
|
|
571
552
|
|
|
572
|
-
|
|
553
|
+
const handleDragStart = () => {
|
|
573
554
|
setIsDragging(true);
|
|
574
555
|
};
|
|
575
556
|
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
}, [props.availableColumns, props.selectedColumns]);
|
|
581
|
-
var handleDragEnd = useCallback(function (dragResult) {
|
|
582
|
-
return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
|
|
583
|
-
}, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
584
|
-
var debouncedSearchHiddenColumns = useMemo(function () {
|
|
585
|
-
return debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300);
|
|
586
|
-
}, [searchHiddenColumns]);
|
|
587
|
-
var handleInputChange = useCallback(function (inputValue) {
|
|
588
|
-
return debouncedSearchHiddenColumns(inputValue);
|
|
589
|
-
}, [debouncedSearchHiddenColumns]);
|
|
557
|
+
const hiddenColumns = useMemo(() => differenceWith(props.availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [props.availableColumns, props.selectedColumns]);
|
|
558
|
+
const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
559
|
+
const debouncedSearchHiddenColumns = useMemo(() => debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300), [searchHiddenColumns]);
|
|
560
|
+
const handleInputChange = useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
590
561
|
return jsx(SettingsContainer$1, {
|
|
591
562
|
title: messages$1.title,
|
|
592
563
|
closeButtonLabel: messages$1.closeButtonLabel,
|
|
@@ -674,7 +645,7 @@ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
674
645
|
managerTheme: _pt.oneOf(['light', 'dark'])
|
|
675
646
|
} : {};
|
|
676
647
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
677
|
-
|
|
648
|
+
const defaultProps = {
|
|
678
649
|
availableColumns: []
|
|
679
650
|
};
|
|
680
651
|
ColumnSettingsManager.defaultProps = defaultProps;
|
|
@@ -700,21 +671,21 @@ var messages = defineMessages({
|
|
|
700
671
|
|
|
701
672
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
702
673
|
|
|
703
|
-
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
674
|
+
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
704
675
|
|
|
705
676
|
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)."; }
|
|
706
677
|
|
|
707
678
|
/* The horizontal constraint is set on this container instead of the SelectInput
|
|
708
679
|
because the input is always empty, and therefore doesn't take any space by itself
|
|
709
680
|
but we want to keep enough space for the placeholder to be readable */
|
|
710
|
-
|
|
681
|
+
const SelectContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
711
682
|
target: "e3i1gnv1"
|
|
712
683
|
} : {
|
|
713
684
|
target: "e3i1gnv1",
|
|
714
685
|
label: "SelectContainer"
|
|
715
686
|
})("min-width:", designTokens.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AA+HkC","file":"data-table-settings.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\nexport type TSelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDisplaySettingsProps = {\n  /**\n   * Set this flag to `false` to show the display settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableDisplaySettings?: boolean;\n\n  /**\n   * Set this to `true` to reduce the paddings of all cells, allowing the table to display\n   * more data in less space.\n   *\n   * @@defaultValue@@: false\n   */\n  isCondensed?: boolean;\n\n  /**\n   * Set this to `true` to allow text in a cell to wrap.\n   * <br>\n   * This is required if `disableDisplaySettings` is set to `false`.\n   *\n   * @@defaultValue@@: false\n   */\n  isWrappingText?: boolean;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the display settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the display settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TColumnManagerProps = {\n  /**\n   * Set this to `true` to show a search input for the hidden columns panel.\n   */\n  areHiddenColumnsSearchable?: boolean;\n\n  /**\n   * Set this to `false` to show the column settings panel option.\n   *\n   * @@defaultValue@@: true\n   */\n  disableColumnManager?: boolean;\n\n  /**\n   * The keys of the visible columns.\n   */\n  visibleColumnKeys: string[];\n\n  /**\n   * The keys of the visible columns.\n   */\n  hideableColumns?: TColumnData[];\n\n  /**\n   * A callback function, called when the search input for the hidden columns panel changes.\n   */\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n\n  /**\n   * Placeholder value of the search input for the hidden columns panel.\n   */\n  searchHiddenColumnsPlaceholder?: string;\n\n  /**\n   * A React element to be rendered as the primary button, useful when the column settings work as a form.\n   */\n  primaryButton?: ReactElement;\n\n  /**\n   * A React element to be rendered as the secondary button, useful when the column settings work as a form.\n   */\n  secondaryButton?: ReactElement;\n};\n\nexport type TDataTableSettingsProps = {\n  topBar?: ReactNode;\n  onSettingsChange?: (\n    settingName: string,\n    settingValue: boolean | string[]\n  ) => void;\n  displaySettings?: TDisplaySettingsProps;\n  columnManager?: TColumnManagerProps;\n  managerTheme?: 'light' | 'dark';\n};\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  min-width: ${designTokens.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const { themedValue } = useTheme();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event: TSelectChangeEvent) =>\n    setOpenedPanelId(\n      Array.isArray(event.target.value)\n        ? event.target.value[0]\n        : event.target.value\n    );\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale={themedValue('s', 'xs')}>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={\n                <TableIcon color={themedValue(undefined, 'neutral60')} />\n              }\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */"));
|
|
716
687
|
|
|
717
|
-
|
|
688
|
+
const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
718
689
|
target: "e3i1gnv0"
|
|
719
690
|
} : {
|
|
720
691
|
target: "e3i1gnv0",
|
|
@@ -729,65 +700,57 @@ var TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
|
|
|
729
700
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
730
701
|
});
|
|
731
702
|
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
var areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
703
|
+
const getDropdownOptions = _ref => {
|
|
704
|
+
let areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
736
705
|
areDisplaySettingsEnabled = _ref.areDisplaySettingsEnabled,
|
|
737
706
|
formatMessage = _ref.formatMessage;
|
|
738
|
-
return
|
|
707
|
+
return [...(areColumnSettingsEnabled ? [{
|
|
739
708
|
value: COLUMN_MANAGER,
|
|
740
709
|
label: formatMessage(messages.columnManagerOption)
|
|
741
|
-
}] : []),
|
|
710
|
+
}] : []), ...(areDisplaySettingsEnabled ? [{
|
|
742
711
|
value: DISPLAY_SETTINGS,
|
|
743
712
|
label: formatMessage(messages.displaySettingsOption)
|
|
744
|
-
}] : [])
|
|
713
|
+
}] : [])];
|
|
745
714
|
};
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
return _reduceInstanceProperty(columns).call(columns,
|
|
749
|
-
|
|
750
|
-
}, {});
|
|
715
|
+
const getMappedColumns = function () {
|
|
716
|
+
let columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
717
|
+
return _reduceInstanceProperty(columns).call(columns, (mappedColumns, column) => _objectSpread$1(_objectSpread$1({}, mappedColumns), {}, {
|
|
718
|
+
[column.key]: column
|
|
719
|
+
}), {});
|
|
751
720
|
};
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
return _mapInstanceProperty(visibleColumnsKeys).call(visibleColumnsKeys,
|
|
755
|
-
return mappedColumns[columnKey];
|
|
756
|
-
});
|
|
721
|
+
const getSelectedColumns = function (mappedColumns) {
|
|
722
|
+
let visibleColumnsKeys = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
723
|
+
return _mapInstanceProperty(visibleColumnsKeys).call(visibleColumnsKeys, columnKey => mappedColumns[columnKey]);
|
|
757
724
|
};
|
|
758
725
|
|
|
759
|
-
|
|
726
|
+
const DataTableSettings = props => {
|
|
760
727
|
var _props$columnManager$, _props$columnManager;
|
|
761
728
|
|
|
762
|
-
|
|
763
|
-
|
|
729
|
+
const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
730
|
+
const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
|
|
764
731
|
process.env.NODE_ENV !== "production" ? warning(areDisplaySettingsEnabled || areColumnSettingsEnabled ? typeof props.onSettingsChange === 'function' : true, "ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.") : void 0;
|
|
765
|
-
|
|
732
|
+
const intl = useIntl();
|
|
766
733
|
|
|
767
|
-
|
|
768
|
-
|
|
734
|
+
const _useTheme = useTheme(),
|
|
735
|
+
themedValue = _useTheme.themedValue;
|
|
769
736
|
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
737
|
+
const _useState = useState(null),
|
|
738
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
739
|
+
openedPanelId = _useState2[0],
|
|
740
|
+
setOpenedPanelId = _useState2[1];
|
|
774
741
|
|
|
775
|
-
|
|
776
|
-
areDisplaySettingsEnabled
|
|
777
|
-
areColumnSettingsEnabled
|
|
742
|
+
const dropdownOptions = getDropdownOptions({
|
|
743
|
+
areDisplaySettingsEnabled,
|
|
744
|
+
areColumnSettingsEnabled,
|
|
778
745
|
formatMessage: intl.formatMessage
|
|
779
746
|
});
|
|
780
747
|
|
|
781
|
-
|
|
782
|
-
return setOpenedPanelId(_Array$isArray(event.target.value) ? event.target.value[0] : event.target.value);
|
|
783
|
-
};
|
|
748
|
+
const handleDropdownChange = event => setOpenedPanelId(_Array$isArray(event.target.value) ? event.target.value[0] : event.target.value);
|
|
784
749
|
|
|
785
|
-
|
|
786
|
-
|
|
750
|
+
const mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
|
|
751
|
+
const selectedColumns = getSelectedColumns(mappedColumns, areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined);
|
|
787
752
|
|
|
788
|
-
|
|
789
|
-
return setOpenedPanelId(null);
|
|
790
|
-
};
|
|
753
|
+
const handleSettingsPanelChange = () => setOpenedPanelId(null);
|
|
791
754
|
|
|
792
755
|
return jsxs(Spacings.Stack, {
|
|
793
756
|
scale: themedValue('s', 'xs'),
|
|
@@ -817,12 +780,12 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
817
780
|
})]
|
|
818
781
|
}), openedPanelId === DISPLAY_SETTINGS && jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
|
|
819
782
|
onClose: handleSettingsPanelChange,
|
|
820
|
-
onDensityDisplayChange:
|
|
783
|
+
onDensityDisplayChange: event => {
|
|
821
784
|
var _props$onSettingsChan;
|
|
822
785
|
|
|
823
786
|
(_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);
|
|
824
787
|
},
|
|
825
|
-
onTextWrappingChange:
|
|
788
|
+
onTextWrappingChange: event => {
|
|
826
789
|
var _props$onSettingsChan2;
|
|
827
790
|
|
|
828
791
|
(_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);
|
|
@@ -832,12 +795,10 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
832
795
|
availableColumns: (_props$columnManager$ = (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
|
|
833
796
|
selectedColumns: selectedColumns,
|
|
834
797
|
onClose: handleSettingsPanelChange,
|
|
835
|
-
onUpdateColumns:
|
|
798
|
+
onUpdateColumns: nextVisibleColumns => {
|
|
836
799
|
var _props$onSettingsChan3;
|
|
837
800
|
|
|
838
|
-
|
|
839
|
-
return visibleColumn.key;
|
|
840
|
-
});
|
|
801
|
+
const keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, visibleColumn => visibleColumn.key);
|
|
841
802
|
|
|
842
803
|
(_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 ? void 0 : _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
|
|
843
804
|
},
|
|
@@ -878,20 +839,18 @@ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (
|
|
|
878
839
|
|
|
879
840
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
880
841
|
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
842
|
+
const DataTableManager = props => {
|
|
843
|
+
const _useTheme = useTheme(),
|
|
844
|
+
themedValue = _useTheme.themedValue;
|
|
884
845
|
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
846
|
+
const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
847
|
+
const isWrappingText = areDisplaySettingsEnabled && props.displaySettings.isWrappingText;
|
|
848
|
+
const columns = useMemo(() => {
|
|
888
849
|
var _context;
|
|
889
850
|
|
|
890
|
-
return _mapInstanceProperty(_context = props.columns).call(_context,
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
});
|
|
894
|
-
});
|
|
851
|
+
return _mapInstanceProperty(_context = props.columns).call(_context, column => _objectSpread(_objectSpread({}, column), {}, {
|
|
852
|
+
isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
|
|
853
|
+
}));
|
|
895
854
|
}, [areDisplaySettingsEnabled, props.columns, isWrappingText]);
|
|
896
855
|
return jsxs(Spacings.Stack, {
|
|
897
856
|
children: [jsx(DataTableSettings$1, {
|
|
@@ -901,7 +860,7 @@ var DataTableManager = function DataTableManager(props) {
|
|
|
901
860
|
displaySettings: props.displaySettings,
|
|
902
861
|
managerTheme: themedValue(props.managerTheme, 'light')
|
|
903
862
|
}), /*#__PURE__*/cloneElement(props.children, {
|
|
904
|
-
columns
|
|
863
|
+
columns,
|
|
905
864
|
isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
|
|
906
865
|
})]
|
|
907
866
|
});
|
|
@@ -930,6 +889,6 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
930
889
|
var DataTableManager$1 = DataTableManager;
|
|
931
890
|
|
|
932
891
|
// NOTE: This string will be replaced on build time with the package version.
|
|
933
|
-
var version = "15.15.
|
|
892
|
+
var version = "15.15.1";
|
|
934
893
|
|
|
935
894
|
export { UPDATE_ACTIONS, DataTableManager$1 as default, version };
|