@commercetools-uikit/data-table-manager 15.14.3 → 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
|
@@ -18,9 +18,7 @@ var designSystem = require('@commercetools-uikit/design-system');
|
|
|
18
18
|
var Spacings = require('@commercetools-uikit/spacings');
|
|
19
19
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
20
20
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
21
|
-
var _toConsumableArray = require('@babel/runtime-corejs3/helpers/toConsumableArray');
|
|
22
21
|
var _styled = require('@emotion/styled/base');
|
|
23
|
-
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
24
22
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
25
23
|
var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
|
|
26
24
|
var utils = require('@commercetools-uikit/utils');
|
|
@@ -42,6 +40,7 @@ var reactBeautifulDnd = require('react-beautiful-dnd');
|
|
|
42
40
|
var debounce = require('debounce-promise');
|
|
43
41
|
var differenceWith = require('lodash/differenceWith');
|
|
44
42
|
var AsyncSelectInput = require('@commercetools-uikit/async-select-input');
|
|
43
|
+
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
45
44
|
var Tag = require('@commercetools-uikit/tag');
|
|
46
45
|
var hooks = require('@commercetools-uikit/hooks');
|
|
47
46
|
|
|
@@ -59,7 +58,6 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
|
|
|
59
58
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
60
59
|
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
61
60
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
62
|
-
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
63
61
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
64
62
|
var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
|
|
65
63
|
var AccessibleHidden__default = /*#__PURE__*/_interopDefault(AccessibleHidden);
|
|
@@ -77,19 +75,20 @@ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceP
|
|
|
77
75
|
var debounce__default = /*#__PURE__*/_interopDefault(debounce);
|
|
78
76
|
var differenceWith__default = /*#__PURE__*/_interopDefault(differenceWith);
|
|
79
77
|
var AsyncSelectInput__default = /*#__PURE__*/_interopDefault(AsyncSelectInput);
|
|
78
|
+
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
80
79
|
var Tag__default = /*#__PURE__*/_interopDefault(Tag);
|
|
81
80
|
|
|
82
|
-
|
|
81
|
+
const UPDATE_ACTIONS = {
|
|
83
82
|
COLUMNS_UPDATE: 'columnsUpdate',
|
|
84
83
|
IS_TABLE_CONDENSED_UPDATE: 'isTableCondensedUpdate',
|
|
85
84
|
IS_TABLE_WRAPPING_TEXT_UPDATE: 'isTableWrappingTextUpdate'
|
|
86
85
|
};
|
|
87
|
-
|
|
88
|
-
|
|
86
|
+
const COLUMN_MANAGER = 'columnManager';
|
|
87
|
+
const DISPLAY_SETTINGS = 'displaySettings';
|
|
89
88
|
|
|
90
89
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
91
90
|
|
|
92
|
-
|
|
91
|
+
const HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
93
92
|
target: "e6ezr101"
|
|
94
93
|
} : {
|
|
95
94
|
target: "e6ezr101",
|
|
@@ -104,23 +103,23 @@ var HeaderContainer = /*#__PURE__*/_styled__default["default"]("div", process.en
|
|
|
104
103
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
105
104
|
});
|
|
106
105
|
|
|
107
|
-
|
|
106
|
+
const CardContentWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
108
107
|
target: "e6ezr100"
|
|
109
108
|
} : {
|
|
110
109
|
target: "e6ezr100",
|
|
111
110
|
label: "CardContentWrapper"
|
|
112
111
|
})("padding:", designSystem.designTokens.paddingForTableManagerSettingsPanel, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0NxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLy8gVE9ETzogQHJlZGVzaWduIGNsZWFudXBcbmltcG9ydCB0eXBlIHsgS2V5Ym9hcmRFdmVudCwgTW91c2VFdmVudCwgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCB0eXBlIE1lc3NhZ2VEZXNjcmlwdG9yIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgQWNjZXNzaWJsZUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9hY2Nlc3NpYmxlLWJ1dHRvbic7XG5pbXBvcnQgQ29sbGFwc2libGVNb3Rpb24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29sbGFwc2libGUtbW90aW9uJztcbmltcG9ydCBDYXJkIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NhcmQnO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgQ2xvc2VJY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zLCB1c2VUaGVtZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG50eXBlIFRTZXR0aW5nc0NvbnRhaW5lclByb3BzID0ge1xuICB0aXRsZTogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgY2xvc2VCdXR0b25MYWJlbDogTWVzc2FnZURlc2NyaXB0b3IgJiB7XG4gICAgdmFsdWVzPzogUmVjb3JkPHN0cmluZywgUmVhY3QuUmVhY3ROb2RlPjtcbiAgfTtcbiAgb25DbG9zZTogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgcHJpbWFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgc2Vjb25kYXJ5QnV0dG9uPzogUmVhY3RFbGVtZW50O1xuICBjaGlsZHJlbjogUmVhY3ROb2RlO1xuICBjb250YWluZXJUaGVtZT86ICdsaWdodCcgfCAnZGFyayc7XG59O1xuXG5jb25zdCBIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xuXG5jb25zdCBDYXJkQ29udGVudFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVGFibGVNYW5hZ2VyU2V0dGluZ3NQYW5lbH07XG5gO1xuXG5jb25zdCBTZXR0aW5nc0NvbnRhaW5lciA9IChwcm9wczogVFNldHRpbmdzQ29udGFpbmVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcbiAgY29uc3QgeyB0aGVtZWRWYWx1ZSB9ID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvbiBpc0RlZmF1bHRDbG9zZWQ9e2ZhbHNlfT5cbiAgICAgIHsoeyByZWdpc3RlckNvbnRlbnROb2RlLCBjb250YWluZXJTdHlsZXMgfSkgPT4gKFxuICAgICAgICA8Q2FyZFxuICAgICAgICAgIHR5cGU9e3RoZW1lZFZhbHVlKCdmbGF0JywgJ3JhaXNlZCcpfVxuICAgICAgICAgIGluc2V0U2NhbGU9XCJub25lXCJcbiAgICAgICAgICB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPXt0aGVtZWRWYWx1ZSgneHMnLCAneGwnKX0+XG4gICAgICAgICAgICAgIDxIZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgICAgPFRleHQuSGVhZGxpbmVcbiAgICAgICAgICAgICAgICAgIGFzPXt0aGVtZWRWYWx1ZSgnaDMnLCAnaDInKX1cbiAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXtwcm9wcy50aXRsZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT17dGhlbWVkVmFsdWUoJ3hzJywgJ2wnKX0+XG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgPGRpdiBzdHlsZT17Y29udGFpbmVyU3R5bGVzfT5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9Pntwcm9wcy5jaGlsZHJlbn08L2Rpdj5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5zZXQ+XG4gICAgICAgICAgICAgICAgeyhwcm9wcy5zZWNvbmRhcnlCdXR0b24gfHwgcHJvcHMucHJpbWFyeUJ1dHRvbikgJiYgKFxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5zZWNvbmRhcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICAgIHtwcm9wcy5wcmltYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgPC9DYXJkQ29udGVudFdyYXBwZXI+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQaWNrPFRTZXR0aW5nc0NvbnRhaW5lclByb3BzLCAnY29udGFpbmVyVGhlbWUnPiA9IHtcbiAgY29udGFpbmVyVGhlbWU6ICdkYXJrJyxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG5cbmV4cG9ydCBkZWZhdWx0IFNldHRpbmdzQ29udGFpbmVyO1xuIl19 */"));
|
|
113
112
|
|
|
114
|
-
|
|
115
|
-
|
|
113
|
+
const SettingsContainer = props => {
|
|
114
|
+
const intl = reactIntl.useIntl();
|
|
116
115
|
|
|
117
|
-
|
|
118
|
-
|
|
116
|
+
const _useTheme = designSystem.useTheme(),
|
|
117
|
+
themedValue = _useTheme.themedValue;
|
|
119
118
|
|
|
120
119
|
return jsxRuntime.jsx(CollapsibleMotion__default["default"], {
|
|
121
120
|
isDefaultClosed: false,
|
|
122
|
-
children:
|
|
123
|
-
|
|
121
|
+
children: _ref => {
|
|
122
|
+
let registerContentNode = _ref.registerContentNode,
|
|
124
123
|
containerStyles = _ref.containerStyles;
|
|
125
124
|
return jsxRuntime.jsx(Card__default["default"], {
|
|
126
125
|
type: themedValue('flat', 'raised'),
|
|
@@ -177,7 +176,7 @@ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
177
176
|
containerTheme: _pt__default["default"].oneOf(['light', 'dark'])
|
|
178
177
|
} : {};
|
|
179
178
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
180
|
-
|
|
179
|
+
const defaultProps$2 = {
|
|
181
180
|
containerTheme: 'dark'
|
|
182
181
|
};
|
|
183
182
|
SettingsContainer.defaultProps = defaultProps$2;
|
|
@@ -226,20 +225,20 @@ var messages$3 = reactIntl.defineMessages({
|
|
|
226
225
|
}
|
|
227
226
|
});
|
|
228
227
|
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
228
|
+
const WRAPPED_TEXT_VISIBLE = 'wrapped-text-visible';
|
|
229
|
+
const SHOW_HIDE_ON_DEMAND = 'show-hide-on-demand';
|
|
230
|
+
const DENSITY_DEFAULT = 'density-default';
|
|
231
|
+
const DENSITY_COMPACT = 'density-compact';
|
|
233
232
|
|
|
234
|
-
|
|
235
|
-
|
|
233
|
+
const DensityManager = props => {
|
|
234
|
+
const intl = reactIntl.useIntl();
|
|
236
235
|
|
|
237
|
-
|
|
238
|
-
|
|
236
|
+
const _useTheme = designSystem.useTheme(),
|
|
237
|
+
themedValue = _useTheme.themedValue;
|
|
239
238
|
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
239
|
+
const textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
240
|
+
const densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_DEFAULT;
|
|
241
|
+
const columnStackScale = themedValue('s', 'l');
|
|
243
242
|
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
244
243
|
title: messages$3.title,
|
|
245
244
|
closeButtonLabel: messages$3.closeButtonLabel,
|
|
@@ -320,7 +319,7 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
320
319
|
managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
|
|
321
320
|
} : {};
|
|
322
321
|
DensityManager.displayName = 'DensityManager';
|
|
323
|
-
|
|
322
|
+
const defaultProps$1 = {
|
|
324
323
|
isCondensed: false,
|
|
325
324
|
isWrappingText: false
|
|
326
325
|
};
|
|
@@ -329,7 +328,7 @@ var DisplaySettingsManager = DensityManager;
|
|
|
329
328
|
|
|
330
329
|
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)."; }
|
|
331
330
|
|
|
332
|
-
|
|
331
|
+
const DraggingSmall = /*#__PURE__*/_styled__default["default"]("small", process.env.NODE_ENV === "production" ? {
|
|
333
332
|
target: "e1mp438g1"
|
|
334
333
|
} : {
|
|
335
334
|
target: "e1mp438g1",
|
|
@@ -344,7 +343,7 @@ var DraggingSmall = /*#__PURE__*/_styled__default["default"]("small", process.en
|
|
|
344
343
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
345
344
|
});
|
|
346
345
|
|
|
347
|
-
|
|
346
|
+
const DraggingContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
348
347
|
target: "e1mp438g0"
|
|
349
348
|
} : {
|
|
350
349
|
target: "e1mp438g0",
|
|
@@ -357,15 +356,15 @@ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys__default["d
|
|
|
357
356
|
|
|
358
357
|
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
359
358
|
|
|
360
|
-
|
|
359
|
+
const DraggableTagWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
361
360
|
target: "emzjy4n0"
|
|
362
361
|
} : {
|
|
363
362
|
target: "emzjy4n0",
|
|
364
363
|
label: "DraggableTagWrapper"
|
|
365
364
|
})("padding:", designSystem.designTokens.paddingForTableManagerDraggableTag, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbmV4cG9ydCB0eXBlIFRDb2x1bW5EYXRhID0ge1xuICBrZXk6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFREcmFnZ2FibGVUYWdQcm9wcyA9IHtcbiAgY29sdW1uOiBUQ29sdW1uRGF0YTtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIG9uUmVtb3ZlPzogKGluZGV4OiBudW1iZXIpID0+IHZvaWQ7XG59O1xuXG5jb25zdCBEcmFnZ2FibGVUYWdXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMucGFkZGluZ0ZvclRhYmxlTWFuYWdlckRyYWdnYWJsZVRhZ307XG5gO1xuXG5jb25zdCBEcmFnZ2FibGVUYWcgPSAocHJvcHM6IFREcmFnZ2FibGVUYWdQcm9wcykgPT4ge1xuICBjb25zdCBoYW5kbGVSZW1vdmVDb2x1bW4gPSAoKSA9PiBwcm9wcy5vblJlbW92ZT8uKHByb3BzLmluZGV4KTtcblxuICByZXR1cm4gKFxuICAgIDxEcmFnZ2FibGVcbiAgICAgIGRyYWdnYWJsZUlkPXtwcm9wcy5jb2x1bW4ua2V5fVxuICAgICAgaW5kZXg9e3Byb3BzLmluZGV4fVxuICAgICAgaXNEcmFnRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgPlxuICAgICAgeyhwcm92aWRlZCkgPT4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxEcmFnZ2FibGVUYWdXcmFwcGVyPlxuICAgICAgICAgICAgPERyYWdnaW5nQ29udGFpbmVyXG4gICAgICAgICAgICAgIHJlZj17cHJvdmlkZWQuaW5uZXJSZWZ9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnZ2FibGVQcm9wc31cbiAgICAgICAgICAgICAgey4uLnByb3ZpZGVkLmRyYWdIYW5kbGVQcm9wc31cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPFRhZ1xuICAgICAgICAgICAgICAgIG9uUmVtb3ZlPXtwcm9wcy5vblJlbW92ZSA/IGhhbmRsZVJlbW92ZUNvbHVtbiA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgICAgIGlzRHJhZ2dhYmxlXG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7cHJvcHMuY29sdW1uLmxhYmVsfVxuICAgICAgICAgICAgICA8L1RhZz5cbiAgICAgICAgICAgIDwvRHJhZ2dpbmdDb250YWluZXI+XG4gICAgICAgICAgPC9EcmFnZ2FibGVUYWdXcmFwcGVyPlxuICAgICAgICApO1xuICAgICAgfX1cbiAgICA8L0RyYWdnYWJsZT5cbiAgKTtcbn07XG5cbkRyYWdnYWJsZVRhZy5kaXNwbGF5TmFtZSA9ICdEcmFnZ2FibGVUYWcnO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2FibGVUYWc7XG4iXX0= */"));
|
|
366
365
|
|
|
367
|
-
|
|
368
|
-
|
|
366
|
+
const DraggableTag = props => {
|
|
367
|
+
const handleRemoveColumn = () => {
|
|
369
368
|
var _props$onRemove;
|
|
370
369
|
|
|
371
370
|
return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
|
|
@@ -375,7 +374,7 @@ var DraggableTag = function DraggableTag(props) {
|
|
|
375
374
|
draggableId: props.column.key,
|
|
376
375
|
index: props.index,
|
|
377
376
|
isDragDisabled: props.isDisabled,
|
|
378
|
-
children:
|
|
377
|
+
children: provided => {
|
|
379
378
|
return jsxRuntime.jsx(DraggableTagWrapper, {
|
|
380
379
|
children: jsxRuntime.jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
|
|
381
380
|
ref: provided.innerRef
|
|
@@ -404,7 +403,7 @@ DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
404
403
|
DraggableTag.displayName = 'DraggableTag';
|
|
405
404
|
var DraggableTag$1 = DraggableTag;
|
|
406
405
|
|
|
407
|
-
|
|
406
|
+
const TagContainerEditable = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
408
407
|
target: "e7rakq0"
|
|
409
408
|
} : {
|
|
410
409
|
target: "e7rakq0",
|
|
@@ -421,10 +420,10 @@ var messages$2 = reactIntl.defineMessages({
|
|
|
421
420
|
}
|
|
422
421
|
});
|
|
423
422
|
|
|
424
|
-
|
|
423
|
+
const DroppablePanel = props => {
|
|
425
424
|
return jsxRuntime.jsx(reactBeautifulDnd.Droppable, {
|
|
426
425
|
droppableId: props.droppableId,
|
|
427
|
-
children:
|
|
426
|
+
children: provided => {
|
|
428
427
|
var _context;
|
|
429
428
|
|
|
430
429
|
return jsxRuntime.jsxs(TagContainerEditable$1, {
|
|
@@ -437,16 +436,16 @@ var DroppablePanel = function DroppablePanel(props) {
|
|
|
437
436
|
children: props.noColumnsText
|
|
438
437
|
})
|
|
439
438
|
}) : jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
440
|
-
children: [_mapInstanceProperty__default["default"](_context = props.columns).call(_context,
|
|
439
|
+
children: [_mapInstanceProperty__default["default"](_context = props.columns).call(_context, (column, index) => {
|
|
441
440
|
var _context2;
|
|
442
441
|
|
|
443
442
|
return jsxRuntime.jsx(DraggableTag$1, {
|
|
444
443
|
column: column,
|
|
445
444
|
index: index,
|
|
446
|
-
onRemove: props.onRemove ?
|
|
447
|
-
var _context3, _context4
|
|
445
|
+
onRemove: props.onRemove ? () => {
|
|
446
|
+
var _context3, _context4;
|
|
448
447
|
|
|
449
|
-
return props.onRemove(
|
|
448
|
+
return props.onRemove([..._sliceInstanceProperty__default["default"](_context3 = props.columns).call(_context3, 0, index), ..._sliceInstanceProperty__default["default"](_context4 = props.columns).call(_context4, index + 1)]);
|
|
450
449
|
} : undefined,
|
|
451
450
|
isDisabled: props.isDisabled
|
|
452
451
|
}, _concatInstanceProperty__default["default"](_context2 = "".concat(column.key, "-")).call(_context2, index));
|
|
@@ -510,121 +509,93 @@ var messages$1 = reactIntl.defineMessages({
|
|
|
510
509
|
}
|
|
511
510
|
});
|
|
512
511
|
|
|
513
|
-
|
|
514
|
-
|
|
512
|
+
const HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
513
|
+
const SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
515
514
|
|
|
516
515
|
function ownKeys$2(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; }
|
|
517
516
|
|
|
518
|
-
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
517
|
+
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__default["default"](_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
519
518
|
|
|
520
|
-
|
|
521
|
-
return _Promise__default["default"].resolve([]);
|
|
522
|
-
}; // 'onChange' prop in AsyncSelectInput is required but not needed here
|
|
519
|
+
const noSearch = () => _Promise__default["default"].resolve([]); // 'onChange' prop in AsyncSelectInput is required but not needed here
|
|
523
520
|
|
|
524
521
|
|
|
525
|
-
|
|
526
|
-
return undefined;
|
|
527
|
-
};
|
|
522
|
+
const voidChangeHandler = () => undefined;
|
|
528
523
|
|
|
529
|
-
|
|
524
|
+
const DroppableContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
530
525
|
target: "en01od20"
|
|
531
526
|
} : {
|
|
532
527
|
target: "en01od20",
|
|
533
528
|
label: "DroppableContainer"
|
|
534
|
-
})("width:100%;position:relative;max-width:", designSystem.designTokens.constraint10, ";cursor:", function (props) {
|
|
535
|
-
return props.isDragging ? 'grabbing' : 'auto';
|
|
536
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AAgE+D","file":"column-settings-manager.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\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"]} */"));
|
|
529
|
+
})("width:100%;position:relative;max-width:", designSystem.designTokens.constraint10, ";cursor:", props => props.isDragging ? 'grabbing' : 'auto', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AAgE+D","file":"column-settings-manager.tsx","sourcesContent":["// 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"]} */"));
|
|
537
530
|
|
|
538
|
-
|
|
531
|
+
const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
|
|
539
532
|
setIsDragging(false); // Invalid drop destination, do nothing
|
|
540
533
|
|
|
541
534
|
if (!dragResult.destination) return;
|
|
542
535
|
|
|
543
536
|
if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {
|
|
544
|
-
var _context;
|
|
545
|
-
|
|
546
537
|
if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
|
|
547
|
-
onUpdateColumns(
|
|
538
|
+
onUpdateColumns([..._sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, dragResult.source.index + 1)]);
|
|
548
539
|
} else {
|
|
549
|
-
var _context2;
|
|
550
|
-
|
|
551
540
|
// the destination is the selected columns panel
|
|
552
541
|
// it's a swap when the source and the destination are the same
|
|
553
|
-
|
|
554
|
-
|
|
542
|
+
const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
|
|
543
|
+
const items = isSwap ? // remove the dragged item from its position if it is not coming from
|
|
555
544
|
// the hidden section (it is a swap)
|
|
556
|
-
|
|
557
|
-
|
|
545
|
+
[..._sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, dragResult.source.index + 1)] : selectedColumns;
|
|
546
|
+
const columns = isSwap ? selectedColumns : availableColumns;
|
|
558
547
|
|
|
559
|
-
|
|
560
|
-
return col.key === dragResult.draggableId;
|
|
561
|
-
}); // push the column in the new position if draggedColumn is found
|
|
548
|
+
const draggedColumn = _findInstanceProperty__default["default"](columns).call(columns, col => col.key === dragResult.draggableId); // push the column in the new position if draggedColumn is found
|
|
562
549
|
|
|
563
550
|
|
|
564
551
|
if (draggedColumn) {
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
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))));
|
|
552
|
+
onUpdateColumns([..._sliceInstanceProperty__default["default"](items).call(items, 0, dragResult.destination.index), draggedColumn, ..._sliceInstanceProperty__default["default"](items).call(items, dragResult.destination.index)]);
|
|
568
553
|
}
|
|
569
554
|
}
|
|
570
555
|
};
|
|
571
556
|
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
});
|
|
580
|
-
};
|
|
557
|
+
const DropdownIndicator = () => jsxRuntime.jsx(Spacings__default["default"].Inline, {
|
|
558
|
+
alignItems: "center",
|
|
559
|
+
children: jsxRuntime.jsx(icons.SearchIcon, {
|
|
560
|
+
size: "medium",
|
|
561
|
+
color: "primary"
|
|
562
|
+
})
|
|
563
|
+
});
|
|
581
564
|
|
|
582
565
|
DropdownIndicator.displayName = 'DropdownIndicator';
|
|
583
566
|
|
|
584
|
-
|
|
585
|
-
return null;
|
|
586
|
-
};
|
|
567
|
+
const Nothing = () => null;
|
|
587
568
|
|
|
588
|
-
|
|
569
|
+
const selectInputComponents = {
|
|
589
570
|
Option: Nothing,
|
|
590
571
|
Menu: Nothing,
|
|
591
|
-
DropdownIndicator
|
|
572
|
+
DropdownIndicator
|
|
592
573
|
};
|
|
593
|
-
|
|
574
|
+
const ColumnSettingsManager = props => {
|
|
594
575
|
if (props.areHiddenColumnsSearchable) {
|
|
595
576
|
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
|
|
596
577
|
}
|
|
597
578
|
|
|
598
|
-
|
|
579
|
+
const intl = reactIntl.useIntl();
|
|
599
580
|
|
|
600
|
-
|
|
601
|
-
|
|
581
|
+
const _useTheme = designSystem.useTheme(),
|
|
582
|
+
themedValue = _useTheme.themedValue;
|
|
602
583
|
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
584
|
+
const _useState = react.useState(false),
|
|
585
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
586
|
+
isDragging = _useState2[0],
|
|
587
|
+
setIsDragging = _useState2[1];
|
|
607
588
|
|
|
608
|
-
|
|
589
|
+
const searchHiddenColumns = props.searchHiddenColumns;
|
|
609
590
|
|
|
610
|
-
|
|
591
|
+
const handleDragStart = () => {
|
|
611
592
|
setIsDragging(true);
|
|
612
593
|
};
|
|
613
594
|
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
}, [props.availableColumns, props.selectedColumns]);
|
|
619
|
-
var handleDragEnd = react.useCallback(function (dragResult) {
|
|
620
|
-
return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
|
|
621
|
-
}, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
622
|
-
var debouncedSearchHiddenColumns = react.useMemo(function () {
|
|
623
|
-
return debounce__default["default"](searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300);
|
|
624
|
-
}, [searchHiddenColumns]);
|
|
625
|
-
var handleInputChange = react.useCallback(function (inputValue) {
|
|
626
|
-
return debouncedSearchHiddenColumns(inputValue);
|
|
627
|
-
}, [debouncedSearchHiddenColumns]);
|
|
595
|
+
const hiddenColumns = react.useMemo(() => differenceWith__default["default"](props.availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [props.availableColumns, props.selectedColumns]);
|
|
596
|
+
const handleDragEnd = react.useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
597
|
+
const debouncedSearchHiddenColumns = react.useMemo(() => debounce__default["default"](searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300), [searchHiddenColumns]);
|
|
598
|
+
const handleInputChange = react.useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
628
599
|
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
629
600
|
title: messages$1.title,
|
|
630
601
|
closeButtonLabel: messages$1.closeButtonLabel,
|
|
@@ -712,7 +683,7 @@ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
712
683
|
managerTheme: _pt__default["default"].oneOf(['light', 'dark'])
|
|
713
684
|
} : {};
|
|
714
685
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
715
|
-
|
|
686
|
+
const defaultProps = {
|
|
716
687
|
availableColumns: []
|
|
717
688
|
};
|
|
718
689
|
ColumnSettingsManager.defaultProps = defaultProps;
|
|
@@ -738,21 +709,21 @@ var messages = reactIntl.defineMessages({
|
|
|
738
709
|
|
|
739
710
|
function ownKeys$1(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; }
|
|
740
711
|
|
|
741
|
-
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
712
|
+
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__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
742
713
|
|
|
743
714
|
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)."; }
|
|
744
715
|
|
|
745
716
|
/* The horizontal constraint is set on this container instead of the SelectInput
|
|
746
717
|
because the input is always empty, and therefore doesn't take any space by itself
|
|
747
718
|
but we want to keep enough space for the placeholder to be readable */
|
|
748
|
-
|
|
719
|
+
const SelectContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
749
720
|
target: "e3i1gnv1"
|
|
750
721
|
} : {
|
|
751
722
|
target: "e3i1gnv1",
|
|
752
723
|
label: "SelectContainer"
|
|
753
724
|
})("min-width:", designSystem.designTokens.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AA+HkC","file":"data-table-settings.tsx","sourcesContent":["// TODO: @redesign cleanup\nimport { useState, type ReactElement, type ReactNode } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\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"]} */"));
|
|
754
725
|
|
|
755
|
-
|
|
726
|
+
const TopBarContainer = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
756
727
|
target: "e3i1gnv0"
|
|
757
728
|
} : {
|
|
758
729
|
target: "e3i1gnv0",
|
|
@@ -767,65 +738,57 @@ var TopBarContainer = /*#__PURE__*/_styled__default["default"]("div", process.en
|
|
|
767
738
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
768
739
|
});
|
|
769
740
|
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
var areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
741
|
+
const getDropdownOptions = _ref => {
|
|
742
|
+
let areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
774
743
|
areDisplaySettingsEnabled = _ref.areDisplaySettingsEnabled,
|
|
775
744
|
formatMessage = _ref.formatMessage;
|
|
776
|
-
return
|
|
745
|
+
return [...(areColumnSettingsEnabled ? [{
|
|
777
746
|
value: COLUMN_MANAGER,
|
|
778
747
|
label: formatMessage(messages.columnManagerOption)
|
|
779
|
-
}] : []),
|
|
748
|
+
}] : []), ...(areDisplaySettingsEnabled ? [{
|
|
780
749
|
value: DISPLAY_SETTINGS,
|
|
781
750
|
label: formatMessage(messages.displaySettingsOption)
|
|
782
|
-
}] : [])
|
|
751
|
+
}] : [])];
|
|
783
752
|
};
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
return _reduceInstanceProperty__default["default"](columns).call(columns,
|
|
787
|
-
|
|
788
|
-
}, {});
|
|
753
|
+
const getMappedColumns = function () {
|
|
754
|
+
let columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
755
|
+
return _reduceInstanceProperty__default["default"](columns).call(columns, (mappedColumns, column) => _objectSpread$1(_objectSpread$1({}, mappedColumns), {}, {
|
|
756
|
+
[column.key]: column
|
|
757
|
+
}), {});
|
|
789
758
|
};
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
return _mapInstanceProperty__default["default"](visibleColumnsKeys).call(visibleColumnsKeys,
|
|
793
|
-
return mappedColumns[columnKey];
|
|
794
|
-
});
|
|
759
|
+
const getSelectedColumns = function (mappedColumns) {
|
|
760
|
+
let visibleColumnsKeys = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
761
|
+
return _mapInstanceProperty__default["default"](visibleColumnsKeys).call(visibleColumnsKeys, columnKey => mappedColumns[columnKey]);
|
|
795
762
|
};
|
|
796
763
|
|
|
797
|
-
|
|
764
|
+
const DataTableSettings = props => {
|
|
798
765
|
var _props$columnManager$, _props$columnManager;
|
|
799
766
|
|
|
800
|
-
|
|
801
|
-
|
|
767
|
+
const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
768
|
+
const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
|
|
802
769
|
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;
|
|
803
|
-
|
|
770
|
+
const intl = reactIntl.useIntl();
|
|
804
771
|
|
|
805
|
-
|
|
806
|
-
|
|
772
|
+
const _useTheme = designSystem.useTheme(),
|
|
773
|
+
themedValue = _useTheme.themedValue;
|
|
807
774
|
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
775
|
+
const _useState = react.useState(null),
|
|
776
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
777
|
+
openedPanelId = _useState2[0],
|
|
778
|
+
setOpenedPanelId = _useState2[1];
|
|
812
779
|
|
|
813
|
-
|
|
814
|
-
areDisplaySettingsEnabled
|
|
815
|
-
areColumnSettingsEnabled
|
|
780
|
+
const dropdownOptions = getDropdownOptions({
|
|
781
|
+
areDisplaySettingsEnabled,
|
|
782
|
+
areColumnSettingsEnabled,
|
|
816
783
|
formatMessage: intl.formatMessage
|
|
817
784
|
});
|
|
818
785
|
|
|
819
|
-
|
|
820
|
-
return setOpenedPanelId(_Array$isArray__default["default"](event.target.value) ? event.target.value[0] : event.target.value);
|
|
821
|
-
};
|
|
786
|
+
const handleDropdownChange = event => setOpenedPanelId(_Array$isArray__default["default"](event.target.value) ? event.target.value[0] : event.target.value);
|
|
822
787
|
|
|
823
|
-
|
|
824
|
-
|
|
788
|
+
const mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
|
|
789
|
+
const selectedColumns = getSelectedColumns(mappedColumns, areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined);
|
|
825
790
|
|
|
826
|
-
|
|
827
|
-
return setOpenedPanelId(null);
|
|
828
|
-
};
|
|
791
|
+
const handleSettingsPanelChange = () => setOpenedPanelId(null);
|
|
829
792
|
|
|
830
793
|
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
831
794
|
scale: themedValue('s', 'xs'),
|
|
@@ -855,12 +818,12 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
855
818
|
})]
|
|
856
819
|
}), openedPanelId === DISPLAY_SETTINGS && jsxRuntime.jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
|
|
857
820
|
onClose: handleSettingsPanelChange,
|
|
858
|
-
onDensityDisplayChange:
|
|
821
|
+
onDensityDisplayChange: event => {
|
|
859
822
|
var _props$onSettingsChan;
|
|
860
823
|
|
|
861
824
|
(_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);
|
|
862
825
|
},
|
|
863
|
-
onTextWrappingChange:
|
|
826
|
+
onTextWrappingChange: event => {
|
|
864
827
|
var _props$onSettingsChan2;
|
|
865
828
|
|
|
866
829
|
(_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);
|
|
@@ -870,12 +833,10 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
870
833
|
availableColumns: (_props$columnManager$ = (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
|
|
871
834
|
selectedColumns: selectedColumns,
|
|
872
835
|
onClose: handleSettingsPanelChange,
|
|
873
|
-
onUpdateColumns:
|
|
836
|
+
onUpdateColumns: nextVisibleColumns => {
|
|
874
837
|
var _props$onSettingsChan3;
|
|
875
838
|
|
|
876
|
-
|
|
877
|
-
return visibleColumn.key;
|
|
878
|
-
});
|
|
839
|
+
const keysOfVisibleColumns = _mapInstanceProperty__default["default"](nextVisibleColumns).call(nextVisibleColumns, visibleColumn => visibleColumn.key);
|
|
879
840
|
|
|
880
841
|
(_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 ? void 0 : _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
|
|
881
842
|
},
|
|
@@ -916,20 +877,18 @@ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["def
|
|
|
916
877
|
|
|
917
878
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
918
879
|
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
880
|
+
const DataTableManager = props => {
|
|
881
|
+
const _useTheme = designSystem.useTheme(),
|
|
882
|
+
themedValue = _useTheme.themedValue;
|
|
922
883
|
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
884
|
+
const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
885
|
+
const isWrappingText = areDisplaySettingsEnabled && props.displaySettings.isWrappingText;
|
|
886
|
+
const columns = react.useMemo(() => {
|
|
926
887
|
var _context;
|
|
927
888
|
|
|
928
|
-
return _mapInstanceProperty__default["default"](_context = props.columns).call(_context,
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
});
|
|
932
|
-
});
|
|
889
|
+
return _mapInstanceProperty__default["default"](_context = props.columns).call(_context, column => _objectSpread(_objectSpread({}, column), {}, {
|
|
890
|
+
isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
|
|
891
|
+
}));
|
|
933
892
|
}, [areDisplaySettingsEnabled, props.columns, isWrappingText]);
|
|
934
893
|
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
935
894
|
children: [jsxRuntime.jsx(DataTableSettings$1, {
|
|
@@ -939,7 +898,7 @@ var DataTableManager = function DataTableManager(props) {
|
|
|
939
898
|
displaySettings: props.displaySettings,
|
|
940
899
|
managerTheme: themedValue(props.managerTheme, 'light')
|
|
941
900
|
}), /*#__PURE__*/react.cloneElement(props.children, {
|
|
942
|
-
columns
|
|
901
|
+
columns,
|
|
943
902
|
isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
|
|
944
903
|
})]
|
|
945
904
|
});
|
|
@@ -968,7 +927,7 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
968
927
|
var DataTableManager$1 = DataTableManager;
|
|
969
928
|
|
|
970
929
|
// NOTE: This string will be replaced on build time with the package version.
|
|
971
|
-
var version = "15.
|
|
930
|
+
var version = "15.15.1";
|
|
972
931
|
|
|
973
932
|
Object.defineProperty(exports, 'useRowSelection', {
|
|
974
933
|
enumerable: true,
|