@commercetools-uikit/data-table-manager 12.2.1 → 12.2.5

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.
@@ -9,10 +9,9 @@ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
10
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
11
11
  import PropTypes from 'prop-types';
12
- import React, { useState } from 'react';
12
+ import { useState, useMemo, useCallback, cloneElement } from 'react';
13
13
  import Spacings from '@commercetools-uikit/spacings';
14
- import { jsx } from '@emotion/react';
15
- import _extends from '@babel/runtime-corejs3/helpers/esm/extends';
14
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
16
15
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
17
16
  import _toConsumableArray from '@babel/runtime-corejs3/helpers/esm/toConsumableArray';
18
17
  import _styled from '@emotion/styled/base';
@@ -49,7 +48,7 @@ var UPDATE_ACTIONS = {
49
48
  var COLUMN_MANAGER = 'columnManager';
50
49
  var DISPLAY_SETTINGS = 'displaySettings';
51
50
 
52
- 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)."; }
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
  var HeaderContainer = _styled("div", process.env.NODE_ENV === "production" ? {
55
54
  target: "e16v1mgb0"
@@ -62,40 +61,52 @@ var HeaderContainer = _styled("div", process.env.NODE_ENV === "production" ? {
62
61
  } : {
63
62
  name: "1bhm8h2",
64
63
  styles: "display:flex;flex:1;justify-content:space-between",
65
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0MiLCJmaWxlIjoic2V0dGluZ3MtY29udGFpbmVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cImZsYXRcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgzXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICA8QWNjZXNzaWJsZUJ1dHRvblxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9e3Byb3BzLm9uQ2xvc2V9XG4gICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxDbG9zZUljb24gc2l6ZT1cIm1lZGl1bVwiIC8+XG4gICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgIDwvSGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgc3R5bGU9e2NvbnRhaW5lclN0eWxlc30+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLkluc2V0PlxuICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICB7cHJvcHMuc2Vjb25kYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblNldHRpbmdzQ29udGFpbmVyLnByb3BUeXBlcyA9IHtcbiAgdGl0bGU6IFByb3BUeXBlcy5zaGFwZSh7XG4gICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBkZWZhdWx0TWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICB9KS5pc1JlcXVpcmVkLFxuICBjbG9zZUJ1dHRvbkxhYmVsOiBQcm9wVHlwZXMuc2hhcGUoe1xuICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgZGVmYXVsdE1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgfSkuaXNSZXF1aXJlZCxcbiAgb25DbG9zZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgcHJpbWFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIHNlY29uZGFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICBjb250YWluZXJUaGVtZTogUHJvcFR5cGVzLm9uZU9mKFsnbGlnaHQnLCAnZGFyayddKSxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
65
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
66
66
  });
67
67
 
68
68
  var SettingsContainer = function SettingsContainer(props) {
69
69
  var intl = useIntl();
70
70
  return jsx(CollapsibleMotion, {
71
- isDefaultClosed: false
72
- }, function (_ref) {
73
- var registerContentNode = _ref.registerContentNode,
74
- containerStyles = _ref.containerStyles;
75
- return jsx(Card, {
76
- type: "flat",
77
- theme: props.containerTheme
78
- }, jsx(Spacings.Stack, {
79
- scale: "xs"
80
- }, jsx(HeaderContainer, null, jsx(Text.Headline, {
81
- as: "h3",
82
- intlMessage: props.title
83
- }), jsx(AccessibleButton, {
84
- onClick: props.onClose,
85
- label: intl.formatMessage(props.closeButtonLabel)
86
- }, jsx(CloseIcon, {
87
- size: "medium"
88
- }))), jsx(Spacings.Stack, {
89
- scale: "xs"
90
- }, jsx(Spacings.Inset, {
91
- scale: "s"
92
- }, jsx("div", {
93
- style: containerStyles
94
- }, jsx("div", {
95
- ref: registerContentNode
96
- }, props.children))), (props.secondaryButton || props.primaryButton) && jsx(Spacings.Inline, {
97
- justifyContent: "flex-end"
98
- }, props.secondaryButton, props.primaryButton))));
71
+ isDefaultClosed: false,
72
+ children: function children(_ref) {
73
+ var registerContentNode = _ref.registerContentNode,
74
+ containerStyles = _ref.containerStyles;
75
+ return jsx(Card, {
76
+ type: "flat",
77
+ theme: props.containerTheme,
78
+ children: jsxs(Spacings.Stack, {
79
+ scale: "xs",
80
+ children: [jsxs(HeaderContainer, {
81
+ children: [jsx(Text.Headline, {
82
+ as: "h3",
83
+ intlMessage: props.title
84
+ }), jsx(AccessibleButton, {
85
+ onClick: props.onClose,
86
+ label: intl.formatMessage(props.closeButtonLabel),
87
+ children: jsx(CloseIcon, {
88
+ size: "medium"
89
+ })
90
+ })]
91
+ }), jsxs(Spacings.Stack, {
92
+ scale: "xs",
93
+ children: [jsx(Spacings.Inset, {
94
+ scale: "s",
95
+ children: jsx("div", {
96
+ style: containerStyles,
97
+ children: jsx("div", {
98
+ ref: registerContentNode,
99
+ children: props.children
100
+ })
101
+ })
102
+ }), (props.secondaryButton || props.primaryButton) && jsxs(Spacings.Inline, {
103
+ justifyContent: "flex-end",
104
+ children: [props.secondaryButton, props.primaryButton]
105
+ })]
106
+ })]
107
+ })
108
+ });
109
+ }
99
110
  });
100
111
  };
101
112
 
@@ -118,8 +129,9 @@ SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
118
129
  SettingsContainer.defaultProps = {
119
130
  containerTheme: 'dark'
120
131
  };
132
+ var SettingsContainer$1 = SettingsContainer;
121
133
 
122
- var messages = defineMessages({
134
+ var messages$3 = defineMessages({
123
135
  title: {
124
136
  id: 'UIKit.DataTableManager.DensityManager.title',
125
137
  description: 'Title for the density manager component.',
@@ -171,51 +183,73 @@ var DensityManager = function DensityManager(props) {
171
183
  var intl = useIntl();
172
184
  var textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
173
185
  var densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_DEFAULT;
174
- return jsx(SettingsContainer, {
175
- title: messages.title,
176
- closeButtonLabel: messages.closeButtonLabel,
186
+ return jsx(SettingsContainer$1, {
187
+ title: messages$3.title,
188
+ closeButtonLabel: messages$3.closeButtonLabel,
177
189
  onClose: props.onClose,
178
190
  primaryButton: props.primaryButton,
179
191
  secondaryButton: props.secondaryButton,
180
- containerTheme: props.managerTheme
181
- }, jsx(Grid, {
182
- gridGap: customProperties.spacingM,
183
- gridTemplateColumns: "repeat(2, 1fr)"
184
- }, jsx(Grid.Item, null, jsx(Spacings.Stack, {
185
- scale: "s"
186
- }, jsx(FieldLabel, {
187
- title: intl.formatMessage(messages.textWrappingSubtitle)
188
- }), jsx(AccessibleHiden, null, jsx("label", {
189
- htmlFor: "text-wrapping-0"
190
- }, "Select radio option: display full text"), jsx("label", {
191
- htmlFor: "text-wrapping-1"
192
- }, "Select radio option: display full previews")), jsx(RadioInput.Group, {
193
- id: "text-wrapping",
194
- name: "text-wrapping",
195
- value: textWrappingOption,
196
- onChange: props.onTextWrappingChange
197
- }, jsx(RadioInput.Option, {
198
- value: WRAPPED_TEXT_VISIBLE
199
- }, intl.formatMessage(messages.textWrappingAllWrapVisibleOption)), jsx(RadioInput.Option, {
200
- value: SHOW_HIDE_ON_DEMAND
201
- }, intl.formatMessage(messages.textWrappingShowHideOnDemandOption))))), jsx(Grid.Item, null, jsx(Spacings.Stack, {
202
- scale: "s"
203
- }, jsx(FieldLabel, {
204
- title: intl.formatMessage(messages.densityDisplaySubtitle)
205
- }), jsx(AccessibleHiden, null, jsx("label", {
206
- htmlFor: "density-display-0"
207
- }, "Select radio option: density default"), jsx("label", {
208
- htmlFor: "density-display-1"
209
- }, "Select radio option: density compact")), jsx(RadioInput.Group, {
210
- id: "density-display",
211
- name: "density-display",
212
- value: densityDisplayOption,
213
- onChange: props.onDensityDisplayChange
214
- }, jsx(RadioInput.Option, {
215
- value: DENSITY_DEFAULT
216
- }, intl.formatMessage(messages.densityDisplayDefaultOption)), jsx(RadioInput.Option, {
217
- value: DENSITY_COMPACT
218
- }, intl.formatMessage(messages.densityDisplayCompactOption)))))));
192
+ containerTheme: props.managerTheme,
193
+ children: jsxs(Grid, {
194
+ gridGap: customProperties.spacingM,
195
+ gridTemplateColumns: "repeat(2, 1fr)",
196
+ children: [jsx(Grid.Item, {
197
+ children: jsxs(Spacings.Stack, {
198
+ scale: "s",
199
+ children: [jsx(FieldLabel, {
200
+ title: intl.formatMessage(messages$3.textWrappingSubtitle)
201
+ }), jsxs(AccessibleHiden, {
202
+ children: [jsx("label", {
203
+ htmlFor: "text-wrapping-0",
204
+ children: "Select radio option: display full text"
205
+ }), jsx("label", {
206
+ htmlFor: "text-wrapping-1",
207
+ children: "Select radio option: display full previews"
208
+ })]
209
+ }), jsxs(RadioInput.Group, {
210
+ id: "text-wrapping",
211
+ name: "text-wrapping",
212
+ value: textWrappingOption,
213
+ onChange: props.onTextWrappingChange,
214
+ children: [jsx(RadioInput.Option, {
215
+ value: WRAPPED_TEXT_VISIBLE,
216
+ children: intl.formatMessage(messages$3.textWrappingAllWrapVisibleOption)
217
+ }), jsx(RadioInput.Option, {
218
+ value: SHOW_HIDE_ON_DEMAND,
219
+ children: intl.formatMessage(messages$3.textWrappingShowHideOnDemandOption)
220
+ })]
221
+ })]
222
+ })
223
+ }), jsx(Grid.Item, {
224
+ children: jsxs(Spacings.Stack, {
225
+ scale: "s",
226
+ children: [jsx(FieldLabel, {
227
+ title: intl.formatMessage(messages$3.densityDisplaySubtitle)
228
+ }), jsxs(AccessibleHiden, {
229
+ children: [jsx("label", {
230
+ htmlFor: "density-display-0",
231
+ children: "Select radio option: density default"
232
+ }), jsx("label", {
233
+ htmlFor: "density-display-1",
234
+ children: "Select radio option: density compact"
235
+ })]
236
+ }), jsxs(RadioInput.Group, {
237
+ id: "density-display",
238
+ name: "density-display",
239
+ value: densityDisplayOption,
240
+ onChange: props.onDensityDisplayChange,
241
+ children: [jsx(RadioInput.Option, {
242
+ value: DENSITY_DEFAULT,
243
+ children: intl.formatMessage(messages$3.densityDisplayDefaultOption)
244
+ }), jsx(RadioInput.Option, {
245
+ value: DENSITY_COMPACT,
246
+ children: intl.formatMessage(messages$3.densityDisplayCompactOption)
247
+ })]
248
+ })]
249
+ })
250
+ })]
251
+ })
252
+ });
219
253
  };
220
254
 
221
255
  DensityManager.displayName = 'DensityManager';
@@ -233,6 +267,7 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
233
267
  onClose: PropTypes.func.isRequired,
234
268
  managerTheme: PropTypes.oneOf(['light', 'dark'])
235
269
  } : {};
270
+ var DisplaySettingsManager = DensityManager;
236
271
 
237
272
  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)."; }
238
273
 
@@ -247,6 +282,7 @@ var DraggingSmall = _styled("small", process.env.NODE_ENV === "production" ? {
247
282
  } : {
248
283
  name: "1fhyj3b",
249
284
  styles: "&:hover{cursor:grab;}",
285
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVrQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */",
250
286
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
251
287
  });
252
288
 
@@ -255,7 +291,13 @@ var DraggingContainer = _styled("div", process.env.NODE_ENV === "production" ? {
255
291
  } : {
256
292
  target: "ed3a5rx0",
257
293
  label: "DraggingContainer"
258
- })(DraggingSmall, ";");
294
+ })(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFvQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */"));
295
+
296
+ var DraggingContainer$1 = DraggingContainer;
297
+
298
+ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
299
+
300
+ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$3(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
259
301
 
260
302
  var DraggableTag = function DraggableTag(props) {
261
303
  var handleRemoveColumn = function handleRemoveColumn() {
@@ -265,21 +307,27 @@ var DraggableTag = function DraggableTag(props) {
265
307
  return jsx(Draggable, {
266
308
  draggableId: props.column.key,
267
309
  index: props.index,
268
- isDragDisabled: props.isDisabled
269
- }, function (provided) {
270
- return jsx(Spacings.Inset, {
271
- scale: "xs"
272
- }, jsx(DraggingContainer, _extends({
273
- ref: provided.innerRef
274
- }, provided.draggableProps, provided.dragHandleProps), jsx(Tag, {
275
- onRemove: props.onRemove ? handleRemoveColumn : undefined,
276
- isDisabled: props.isDisabled
277
- }, jsx(Spacings.Inline, {
278
- alignItems: "center"
279
- }, jsx(DragIcon, {
280
- "data-testid": "drag-icon",
281
- size: "medium"
282
- }), props.column.label))), provided.placeholder);
310
+ isDragDisabled: props.isDisabled,
311
+ children: function children(provided) {
312
+ return jsxs(Spacings.Inset, {
313
+ scale: "xs",
314
+ children: [jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
315
+ ref: provided.innerRef
316
+ }, provided.draggableProps), provided.dragHandleProps), {}, {
317
+ children: jsx(Tag, {
318
+ onRemove: props.onRemove ? handleRemoveColumn : undefined,
319
+ isDisabled: props.isDisabled,
320
+ children: jsxs(Spacings.Inline, {
321
+ alignItems: "center",
322
+ children: [jsx(DragIcon, {
323
+ "data-testid": "drag-icon",
324
+ size: "medium"
325
+ }), props.column.label]
326
+ })
327
+ })
328
+ })), provided.placeholder]
329
+ });
330
+ }
283
331
  });
284
332
  };
285
333
 
@@ -293,15 +341,18 @@ DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
293
341
  onRemove: PropTypes.func,
294
342
  isDisabled: PropTypes.bool
295
343
  } : {};
344
+ var DraggableTag$1 = DraggableTag;
296
345
 
297
346
  var TagContainerEditable = _styled("div", process.env.NODE_ENV === "production" ? {
298
347
  target: "ecy2q1d0"
299
348
  } : {
300
349
  target: "ecy2q1d0",
301
350
  label: "TagContainerEditable"
302
- })("background-color:", customProperties.backgroundColorForInput, ";border:", customProperties.borderRadius1, " solid ", customProperties.colorNeutral60, ";border-radius:", customProperties.borderRadius6, ";padding:", customProperties.spacingS, ";height:", customProperties.constraint7, ";overflow:auto;");
351
+ })("background-color:", customProperties.backgroundColorForInput, ";border:", customProperties.borderRadius1, " solid ", customProperties.colorNeutral60, ";border-radius:", customProperties.borderRadius6, ";padding:", customProperties.spacingS, ";height:", customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR3VDIiwiZmlsZSI6InRhZy1jb250YWluZXItZWRpdGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgVGFnQ29udGFpbmVyRWRpdGFibGUgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXR9O1xuICBib3JkZXI6ICR7dmFycy5ib3JkZXJSYWRpdXMxfSBzb2xpZCAke3ZhcnMuY29sb3JOZXV0cmFsNjB9O1xuICBib3JkZXItcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzNn07XG4gIHBhZGRpbmc6ICR7dmFycy5zcGFjaW5nU307XG4gIGhlaWdodDogJHt2YXJzLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
303
352
 
304
- var messages$1 = defineMessages({
353
+ var TagContainerEditable$1 = TagContainerEditable;
354
+
355
+ var messages$2 = defineMessages({
305
356
  loadMoreAttributesHint: {
306
357
  id: 'UIKit.DataTableManager.ColumnManager.DroppablePanel.loadMoreAttributesHint',
307
358
  description: 'Indicate that the user can use the search input to load more attributes',
@@ -311,37 +362,43 @@ var messages$1 = defineMessages({
311
362
 
312
363
  var DroppablePanel = function DroppablePanel(props) {
313
364
  return jsx(Droppable, {
314
- droppableId: props.droppableId
315
- }, function (provided) {
316
- var _context;
317
-
318
- return jsx(TagContainerEditable, {
319
- "data-testid": props.droppableId,
320
- ref: provided.innerRef
321
- }, props.columns.length === 0 ? jsx(Spacings.Inset, {
322
- scale: "s"
323
- }, jsx(Text.Detail, {
324
- tone: "secondary"
325
- }, props.noColumnsText)) : jsx(React.Fragment, null, _mapInstanceProperty(_context = props.columns).call(_context, function (column, index) {
326
- var _context2;
327
-
328
- return jsx(DraggableTag, {
329
- key: _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index),
330
- column: column,
331
- index: index,
332
- onRemove: props.onRemove ? function () {
333
- var _context3, _context4, _context5;
334
-
335
- return props.onRemove(_concatInstanceProperty(_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty(_context4 = props.columns).call(_context4, 0, index)), _toConsumableArray(_sliceInstanceProperty(_context5 = props.columns).call(_context5, index + 1))));
336
- } : undefined,
337
- isDisabled: props.isDisabled
365
+ droppableId: props.droppableId,
366
+ children: function children(provided) {
367
+ var _context;
368
+
369
+ return jsxs(TagContainerEditable$1, {
370
+ "data-testid": props.droppableId,
371
+ ref: provided.innerRef,
372
+ children: [props.columns.length === 0 ? jsx(Spacings.Inset, {
373
+ scale: "s",
374
+ children: jsx(Text.Detail, {
375
+ tone: "secondary",
376
+ children: props.noColumnsText
377
+ })
378
+ }) : jsxs(Fragment, {
379
+ children: [_mapInstanceProperty(_context = props.columns).call(_context, function (column, index) {
380
+ var _context2;
381
+
382
+ return jsx(DraggableTag$1, {
383
+ column: column,
384
+ index: index,
385
+ onRemove: props.onRemove ? function () {
386
+ var _context3, _context4, _context5;
387
+
388
+ return props.onRemove(_concatInstanceProperty(_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty(_context4 = props.columns).call(_context4, 0, index)), _toConsumableArray(_sliceInstanceProperty(_context5 = props.columns).call(_context5, index + 1))));
389
+ } : undefined,
390
+ isDisabled: props.isDisabled
391
+ }, _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index));
392
+ }), props.isSearchable && jsx(Spacings.Inset, {
393
+ scale: "xs",
394
+ children: jsx(Text.Detail, {
395
+ tone: "secondary",
396
+ intlMessage: messages$2.loadMoreAttributesHint
397
+ })
398
+ })]
399
+ }), provided.placeholder]
338
400
  });
339
- }), props.isSearchable && jsx(Spacings.Inset, {
340
- scale: "xs"
341
- }, jsx(Text.Detail, {
342
- tone: "secondary",
343
- intlMessage: messages$1.loadMoreAttributesHint
344
- }))), provided.placeholder);
401
+ }
345
402
  });
346
403
  };
347
404
 
@@ -357,8 +414,9 @@ DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
357
414
  isDisabled: PropTypes.bool,
358
415
  onRemove: PropTypes.func
359
416
  } : {};
417
+ var DroppablePanel$1 = DroppablePanel;
360
418
 
361
- var messages$2 = defineMessages({
419
+ var messages$1 = defineMessages({
362
420
  title: {
363
421
  id: 'UIKit.DataTableManager.ColumnManager.title',
364
422
  description: 'Title for the column manager component.',
@@ -394,6 +452,10 @@ var messages$2 = defineMessages({
394
452
  var HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
395
453
  var SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
396
454
 
455
+ function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
456
+
457
+ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context4; _forEachInstanceProperty(_context4 = ownKeys$2(Object(source), true)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context5; _forEachInstanceProperty(_context5 = ownKeys$2(Object(source))).call(_context5, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
458
+
397
459
  var DroppableContainer = _styled("div", process.env.NODE_ENV === "production" ? {
398
460
  target: "e6ge22w0"
399
461
  } : {
@@ -401,7 +463,7 @@ var DroppableContainer = _styled("div", process.env.NODE_ENV === "production" ?
401
463
  label: "DroppableContainer"
402
464
  })("width:100%;position:relative;max-width:", customProperties.constraint10, ";cursor:", function (props) {
403
465
  return props.isDragging ? 'grabbing' : 'auto';
404
- }, ";");
466
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.js"],"names":[],"mappings":"AAsBqC","file":"column-settings-manager.js","sourcesContent":["import { useMemo, useCallback, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\nconst DroppableContainer = styled.div`\n  width: 100%;\n  position: relative;\n  max-width: ${vars.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult,\n  onUpdateColumns,\n  selectedColumns,\n  availableColumns,\n  setIsDragging\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position\n    onUpdateColumns([\n      ...items.slice(0, dragResult.destination.index),\n      draggedColumn,\n      ...items.slice(dragResult.destination.index),\n    ]);\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon scale=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props) => {\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const handleInputChange = useCallback(\n    (input) =>\n      // loadOptions is not invoked when input is empty\n      !input.length && searchHiddenColumns(input),\n    [searchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"m\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  cacheOptions={false}\n                  onChange={() => {\n                    // to avoid prop-types error\n                    // as `onChange` is a required prop in\n                    // `AsyncSelectInput`\n                  }}\n                  // loadOptions is used instead of onInputChange\n                  // because the loading indicator is displayed\n                  // only when loadOptions is invoked\n                  loadOptions={debounce(searchHiddenColumns, 300)}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nColumnSettingsManager.propTypes = {\n  availableColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  selectedColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  onUpdateColumns: PropTypes.func.isRequired,\n\n  areHiddenColumnsSearchable: PropTypes.bool,\n  searchHiddenColumns: requiredIf(\n    PropTypes.func,\n    (props) => props.areHiddenColumnsSearchable\n  ),\n  searchHiddenColumnsPlaceholder: PropTypes.string,\n\n  onClose: PropTypes.func,\n  primaryButton: PropTypes.element,\n  secondaryButton: PropTypes.element,\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nColumnSettingsManager.defaultProps = {\n  availableColumns: [],\n};\n\nexport default ColumnSettingsManager;\n"]} */"));
405
467
 
406
468
  var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) {
407
469
  setIsDragging(false); // Invalid drop destination, do nothing
@@ -435,11 +497,12 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
435
497
 
436
498
  var DropdownIndicator = function DropdownIndicator() {
437
499
  return jsx(Spacings.Inline, {
438
- alignItems: "center"
439
- }, jsx(SearchIcon, {
440
- scale: "medium",
441
- color: "primary"
442
- }));
500
+ alignItems: "center",
501
+ children: jsx(SearchIcon, {
502
+ scale: "medium",
503
+ color: "primary"
504
+ })
505
+ });
443
506
  };
444
507
 
445
508
  DropdownIndicator.displayName = 'DropdownIndicator';
@@ -467,80 +530,91 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
467
530
  setIsDragging(true);
468
531
  };
469
532
 
470
- var hiddenColumns = React.useMemo(function () {
533
+ var hiddenColumns = useMemo(function () {
471
534
  return differenceWith(props.availableColumns, props.selectedColumns, function (a, b) {
472
535
  return a.key === b.key;
473
536
  });
474
537
  }, [props.availableColumns, props.selectedColumns]);
475
- var handleDragEnd = React.useCallback(function (dragResult) {
538
+ var handleDragEnd = useCallback(function (dragResult) {
476
539
  return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
477
540
  }, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
478
- var handleInputChange = React.useCallback(function (input) {
541
+ var handleInputChange = useCallback(function (input) {
479
542
  return (// loadOptions is not invoked when input is empty
480
543
  !input.length && searchHiddenColumns(input)
481
544
  );
482
545
  }, [searchHiddenColumns]);
483
- return jsx(SettingsContainer, {
484
- title: messages$2.title,
485
- closeButtonLabel: messages$2.closeButtonLabel,
546
+ return jsx(SettingsContainer$1, {
547
+ title: messages$1.title,
548
+ closeButtonLabel: messages$1.closeButtonLabel,
486
549
  onClose: props.onClose,
487
550
  primaryButton: props.primaryButton,
488
551
  secondaryButton: props.secondaryButton,
489
- containerTheme: props.managerTheme
490
- }, jsx(DragDropContext, {
491
- onDragEnd: handleDragEnd,
492
- onDragStart: handleDragStart
493
- }, jsx(Spacings.Inline, {
494
- scale: "m"
495
- }, jsx(DroppableContainer, {
496
- isDragging: isDragging,
497
- "aria-labelledby": "hidden-columns"
498
- }, jsx(Spacings.Stack, null, jsx(Spacings.Inline, {
499
- scale: "xs",
500
- alignItems: "center"
501
- }, jsx(EyeCrossedIcon, {
502
- size: "medium"
503
- }), jsx(FieldLabel, {
504
- id: "hidden-columns",
505
- title: intl.formatMessage(messages$2.hiddenColumns)
506
- })), props.areHiddenColumnsSearchable && jsx(AsyncSelectInput, _extends({}, props.searchHiddenColumnsPlaceholder ? {
507
- placeholder: props.searchHiddenColumnsPlaceholder
508
- } : undefined, {
509
- cacheOptions: false,
510
- onChange: function onChange() {// to avoid prop-types error
511
- // as `onChange` is a required prop in
512
- // `AsyncSelectInput`
513
- } // loadOptions is used instead of onInputChange
514
- // because the loading indicator is displayed
515
- // only when loadOptions is invoked
516
- ,
517
- loadOptions: debounce(searchHiddenColumns, 300),
518
- onInputChange: handleInputChange,
519
- components: selectInputComponents
520
- })), jsx(DroppablePanel, {
521
- droppableId: HIDDEN_COLUMNS_PANEL,
522
- "data-testid": HIDDEN_COLUMNS_PANEL,
523
- noColumnsText: intl.formatMessage(messages$2.noHiddenColumnsToShow),
524
- columns: hiddenColumns,
525
- isSearchable: props.areHiddenColumnsSearchable
526
- }))), jsx(DroppableContainer, {
527
- isDragging: isDragging,
528
- "aria-labelledby": "visible-columns"
529
- }, jsx(Spacings.Stack, null, jsx(Spacings.Inline, {
530
- scale: "xs",
531
- alignItems: "center"
532
- }, jsx(EyeIcon, {
533
- size: "medium"
534
- }), jsx(FieldLabel, {
535
- id: "visible-columns",
536
- title: intl.formatMessage(messages$2.visibleColumns)
537
- })), jsx(DroppablePanel, {
538
- droppableId: SELECTED_COLUMNS_PANEL,
539
- "data-testid": SELECTED_COLUMNS_PANEL,
540
- noColumnsText: intl.formatMessage(messages$2.noSelectedColumnsToShow),
541
- columns: props.selectedColumns,
542
- onRemove: props.onUpdateColumns
543
- }))))));
552
+ containerTheme: props.managerTheme,
553
+ children: jsx(DragDropContext, {
554
+ onDragEnd: handleDragEnd,
555
+ onDragStart: handleDragStart,
556
+ children: jsxs(Spacings.Inline, {
557
+ scale: "m",
558
+ children: [jsx(DroppableContainer, {
559
+ isDragging: isDragging,
560
+ "aria-labelledby": "hidden-columns",
561
+ children: jsxs(Spacings.Stack, {
562
+ children: [jsxs(Spacings.Inline, {
563
+ scale: "xs",
564
+ alignItems: "center",
565
+ children: [jsx(EyeCrossedIcon, {
566
+ size: "medium"
567
+ }), jsx(FieldLabel, {
568
+ id: "hidden-columns",
569
+ title: intl.formatMessage(messages$1.hiddenColumns)
570
+ })]
571
+ }), props.areHiddenColumnsSearchable && jsx(AsyncSelectInput, _objectSpread$2(_objectSpread$2({}, props.searchHiddenColumnsPlaceholder ? {
572
+ placeholder: props.searchHiddenColumnsPlaceholder
573
+ } : undefined), {}, {
574
+ cacheOptions: false,
575
+ onChange: function onChange() {// to avoid prop-types error
576
+ // as `onChange` is a required prop in
577
+ // `AsyncSelectInput`
578
+ } // loadOptions is used instead of onInputChange
579
+ // because the loading indicator is displayed
580
+ // only when loadOptions is invoked
581
+ ,
582
+ loadOptions: debounce(searchHiddenColumns, 300),
583
+ onInputChange: handleInputChange,
584
+ components: selectInputComponents
585
+ })), jsx(DroppablePanel$1, {
586
+ droppableId: HIDDEN_COLUMNS_PANEL,
587
+ "data-testid": HIDDEN_COLUMNS_PANEL,
588
+ noColumnsText: intl.formatMessage(messages$1.noHiddenColumnsToShow),
589
+ columns: hiddenColumns,
590
+ isSearchable: props.areHiddenColumnsSearchable
591
+ })]
592
+ })
593
+ }), jsx(DroppableContainer, {
594
+ isDragging: isDragging,
595
+ "aria-labelledby": "visible-columns",
596
+ children: jsxs(Spacings.Stack, {
597
+ children: [jsxs(Spacings.Inline, {
598
+ scale: "xs",
599
+ alignItems: "center",
600
+ children: [jsx(EyeIcon, {
601
+ size: "medium"
602
+ }), jsx(FieldLabel, {
603
+ id: "visible-columns",
604
+ title: intl.formatMessage(messages$1.visibleColumns)
605
+ })]
606
+ }), jsx(DroppablePanel$1, {
607
+ droppableId: SELECTED_COLUMNS_PANEL,
608
+ "data-testid": SELECTED_COLUMNS_PANEL,
609
+ noColumnsText: intl.formatMessage(messages$1.noSelectedColumnsToShow),
610
+ columns: props.selectedColumns,
611
+ onRemove: props.onUpdateColumns
612
+ })]
613
+ })
614
+ })]
615
+ })
616
+ })
617
+ });
544
618
  };
545
619
  ColumnSettingsManager.displayName = 'ColumnSettingsManager';
546
620
  ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
@@ -566,8 +640,9 @@ ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
566
640
  ColumnSettingsManager.defaultProps = {
567
641
  availableColumns: []
568
642
  };
643
+ var ColumnSettingsManager$1 = ColumnSettingsManager;
569
644
 
570
- var messages$3 = defineMessages({
645
+ var messages = defineMessages({
571
646
  placeholder: {
572
647
  id: 'UIKit.DataTableManager.TableSettings.placeholder',
573
648
  description: 'Placeholder for the table settings select component.',
@@ -585,20 +660,18 @@ var messages$3 = defineMessages({
585
660
  }
586
661
  });
587
662
 
588
- var _PropTypes$shape;
589
-
590
- function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
663
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
591
664
 
592
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
665
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys$1(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
593
666
 
594
- 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)."; }
667
+ 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)."; }
595
668
 
596
669
  var SelectContainer = _styled("div", process.env.NODE_ENV === "production" ? {
597
670
  target: "eh8k7x01"
598
671
  } : {
599
672
  target: "eh8k7x01",
600
673
  label: "SelectContainer"
601
- })("width:", customProperties.constraint4, ";");
674
+ })("width:", customProperties.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAqBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager.hideableColumns}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */"));
602
675
 
603
676
  var TopBarContainer = _styled("div", process.env.NODE_ENV === "production" ? {
604
677
  target: "eh8k7x00"
@@ -611,7 +684,8 @@ var TopBarContainer = _styled("div", process.env.NODE_ENV === "production" ? {
611
684
  } : {
612
685
  name: "1ff36h2",
613
686
  styles: "flex-grow:1",
614
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
687
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAyBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager.hideableColumns}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */",
688
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
615
689
  });
616
690
 
617
691
  var getDropdownOptions = function getDropdownOptions(_ref) {
@@ -622,16 +696,16 @@ var getDropdownOptions = function getDropdownOptions(_ref) {
622
696
  formatMessage = _ref.formatMessage;
623
697
  return _concatInstanceProperty(_context = []).call(_context, _toConsumableArray(areColumnSettingsEnabled ? [{
624
698
  value: COLUMN_MANAGER,
625
- label: formatMessage(messages$3.columnManagerOption)
699
+ label: formatMessage(messages.columnManagerOption)
626
700
  }] : []), _toConsumableArray(areDisplaySettingsEnabled ? [{
627
701
  value: DISPLAY_SETTINGS,
628
- label: formatMessage(messages$3.displaySettingsOption)
702
+ label: formatMessage(messages.displaySettingsOption)
629
703
  }] : []));
630
704
  };
631
705
  var getMappedColumns = function getMappedColumns() {
632
706
  var columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
633
707
  return _reduceInstanceProperty(columns).call(columns, function (mappedColumns, column) {
634
- return _objectSpread(_objectSpread({}, mappedColumns), {}, _defineProperty({}, column.key, column));
708
+ return _objectSpread$1(_objectSpread$1({}, mappedColumns), {}, _defineProperty({}, column.key, column));
635
709
  }, {});
636
710
  };
637
711
  var getSelectedColumns = function getSelectedColumns(mappedColumns) {
@@ -669,42 +743,52 @@ var DataTableSettings = function DataTableSettings(props) {
669
743
  return setOpenedPanelId(null);
670
744
  };
671
745
 
672
- return jsx(Spacings.Stack, null, jsx(Spacings.Inline, {
673
- justifyContent: "space-between",
674
- alignItems: "center"
675
- }, jsx(TopBarContainer, null, props.topBar), dropdownOptions.length > 0 && jsx(SelectContainer, null, jsx(AccessibleHiden, null, jsx("label", {
676
- htmlFor: "table-settings-dropdown"
677
- }, "Open table manager dropdown")), jsx(SelectInput, {
678
- id: "table-settings-dropdown" // the dropdown always shows the placeholder as selecting an option
679
- // will open the corresponding panel (column manager or display settings)
680
- ,
681
- value: "",
682
- placeholder: intl.formatMessage(messages$3.placeholder),
683
- onChange: handleDropdownChange,
684
- options: dropdownOptions,
685
- iconLeft: jsx(TableIcon, null)
686
- }))), openedPanelId === DISPLAY_SETTINGS && jsx(DensityManager, _extends({}, props.displaySettings || {}, {
687
- onClose: handleSettingsPanelChange,
688
- onDensityDisplayChange: function onDensityDisplayChange(event) {
689
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
690
- },
691
- onTextWrappingChange: function onTextWrappingChange(event) {
692
- props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
693
- },
694
- managerTheme: props.managerTheme
695
- })), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager, _extends({}, props.columnManager || {}, {
696
- availableColumns: props.columnManager.hideableColumns,
697
- selectedColumns: selectedColumns,
698
- onClose: handleSettingsPanelChange,
699
- onUpdateColumns: function onUpdateColumns(nextVisibleColumns) {
700
- var keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, function (visibleColumn) {
701
- return visibleColumn.key;
702
- });
703
-
704
- props.onSettingsChange(UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
705
- },
706
- managerTheme: props.managerTheme
707
- })));
746
+ return jsxs(Spacings.Stack, {
747
+ children: [jsxs(Spacings.Inline, {
748
+ justifyContent: "space-between",
749
+ alignItems: "center",
750
+ children: [jsx(TopBarContainer, {
751
+ children: props.topBar
752
+ }), dropdownOptions.length > 0 && jsxs(SelectContainer, {
753
+ children: [jsx(AccessibleHiden, {
754
+ children: jsx("label", {
755
+ htmlFor: "table-settings-dropdown",
756
+ children: "Open table manager dropdown"
757
+ })
758
+ }), jsx(SelectInput, {
759
+ id: "table-settings-dropdown" // the dropdown always shows the placeholder as selecting an option
760
+ // will open the corresponding panel (column manager or display settings)
761
+ ,
762
+ value: "",
763
+ placeholder: intl.formatMessage(messages.placeholder),
764
+ onChange: handleDropdownChange,
765
+ options: dropdownOptions,
766
+ iconLeft: jsx(TableIcon, {})
767
+ })]
768
+ })]
769
+ }), openedPanelId === DISPLAY_SETTINGS && jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
770
+ onClose: handleSettingsPanelChange,
771
+ onDensityDisplayChange: function onDensityDisplayChange(event) {
772
+ props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
773
+ },
774
+ onTextWrappingChange: function onTextWrappingChange(event) {
775
+ props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
776
+ },
777
+ managerTheme: props.managerTheme
778
+ })), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager$1, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
779
+ availableColumns: props.columnManager.hideableColumns,
780
+ selectedColumns: selectedColumns,
781
+ onClose: handleSettingsPanelChange,
782
+ onUpdateColumns: function onUpdateColumns(nextVisibleColumns) {
783
+ var keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, function (visibleColumn) {
784
+ return visibleColumn.key;
785
+ });
786
+
787
+ props.onSettingsChange(UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
788
+ },
789
+ managerTheme: props.managerTheme
790
+ }))]
791
+ });
708
792
  };
709
793
 
710
794
  DataTableSettings.displayName = 'DataTableSettings';
@@ -718,44 +802,51 @@ DataTableSettings.propTypes = process.env.NODE_ENV !== "production" ? {
718
802
  primaryButton: PropTypes.element,
719
803
  secondaryButton: PropTypes.element
720
804
  }),
721
- columnManager: PropTypes.shape((_PropTypes$shape = {
805
+ columnManager: PropTypes.shape({
722
806
  areHiddenColumnsSearchable: PropTypes.bool,
723
807
  disableColumnManager: PropTypes.bool,
724
808
  visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),
725
809
  hideableColumns: PropTypes.arrayOf(PropTypes.shape({
726
810
  key: PropTypes.string.isRequired,
727
811
  label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired
728
- }))
729
- }, _defineProperty(_PropTypes$shape, "areHiddenColumnsSearchable", PropTypes.bool), _defineProperty(_PropTypes$shape, "searchHiddenColumns", PropTypes.func), _defineProperty(_PropTypes$shape, "searchHiddenColumnsPlaceholder", PropTypes.string), _defineProperty(_PropTypes$shape, "primaryButton", PropTypes.element), _defineProperty(_PropTypes$shape, "secondaryButton", PropTypes.element), _PropTypes$shape)),
812
+ })),
813
+ searchHiddenColumns: PropTypes.func,
814
+ searchHiddenColumnsPlaceholder: PropTypes.string,
815
+ primaryButton: PropTypes.element,
816
+ secondaryButton: PropTypes.element
817
+ }),
730
818
  managerTheme: PropTypes.oneOf(['light', 'dark'])
731
819
  } : {};
820
+ var DataTableSettings$1 = DataTableSettings;
732
821
 
733
- function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
822
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
734
823
 
735
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys$1(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
824
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
736
825
 
737
826
  var DataTableManager = function DataTableManager(props) {
738
827
  var areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
739
828
  var isWrappingText = areDisplaySettingsEnabled && props.displaySettings.isWrappingText;
740
- var columns = React.useMemo(function () {
829
+ var columns = useMemo(function () {
741
830
  var _context;
742
831
 
743
832
  return _mapInstanceProperty(_context = props.columns).call(_context, function (column) {
744
- return _objectSpread$1(_objectSpread$1({}, column), {}, {
833
+ return _objectSpread(_objectSpread({}, column), {}, {
745
834
  isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
746
835
  });
747
836
  });
748
837
  }, [areDisplaySettingsEnabled, props.columns, isWrappingText]);
749
- return jsx(Spacings.Stack, null, jsx(DataTableSettings, {
750
- topBar: props.topBar,
751
- onSettingsChange: props.onSettingsChange,
752
- columnManager: props.columnManager,
753
- displaySettings: props.displaySettings,
754
- managerTheme: props.managerTheme
755
- }), /*#__PURE__*/React.cloneElement(props.children, {
756
- columns: columns,
757
- isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
758
- }));
838
+ return jsxs(Spacings.Stack, {
839
+ children: [jsx(DataTableSettings$1, {
840
+ topBar: props.topBar,
841
+ onSettingsChange: props.onSettingsChange,
842
+ columnManager: props.columnManager,
843
+ displaySettings: props.displaySettings,
844
+ managerTheme: props.managerTheme
845
+ }), /*#__PURE__*/cloneElement(props.children, {
846
+ columns: columns,
847
+ isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
848
+ })]
849
+ });
759
850
  };
760
851
 
761
852
  DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
@@ -982,9 +1073,9 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
982
1073
  managerTheme: PropTypes.oneOf(['light', 'dark'])
983
1074
  } : {};
984
1075
  DataTableManager.displayName = 'DataTableManager';
1076
+ var DataTableManager$1 = DataTableManager;
985
1077
 
986
- // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
987
- var version = '12.2.1';
1078
+ // NOTE: This string will be replaced on build time with the package version.
1079
+ var version = "12.2.5";
988
1080
 
989
- export default DataTableManager;
990
- export { UPDATE_ACTIONS, version };
1081
+ export { UPDATE_ACTIONS, DataTableManager$1 as default, version };