@commercetools-uikit/data-table-manager 12.2.2 → 12.2.6
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.
|
@@ -13,10 +13,9 @@ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/obje
|
|
|
13
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
14
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
15
15
|
var PropTypes = require('prop-types');
|
|
16
|
-
var
|
|
16
|
+
var react = require('react');
|
|
17
17
|
var Spacings = require('@commercetools-uikit/spacings');
|
|
18
|
-
var
|
|
19
|
-
var _extends = require('@babel/runtime-corejs3/helpers/extends');
|
|
18
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
20
19
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
21
20
|
var _toConsumableArray = require('@babel/runtime-corejs3/helpers/toConsumableArray');
|
|
22
21
|
var _styled = require('@emotion/styled/base');
|
|
@@ -57,7 +56,6 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
|
|
|
57
56
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
58
57
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
59
58
|
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
60
|
-
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
61
59
|
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
62
60
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
63
61
|
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
@@ -89,7 +87,7 @@ var DISPLAY_SETTINGS = 'displaySettings';
|
|
|
89
87
|
|
|
90
88
|
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
89
|
|
|
92
|
-
var HeaderContainer = _styled__default[
|
|
90
|
+
var HeaderContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
93
91
|
target: "e16v1mgb0"
|
|
94
92
|
} : {
|
|
95
93
|
target: "e16v1mgb0",
|
|
@@ -100,58 +98,70 @@ var HeaderContainer = _styled__default['default']("div", process.env.NODE_ENV ==
|
|
|
100
98
|
} : {
|
|
101
99
|
name: "1bhm8h2",
|
|
102
100
|
styles: "display:flex;flex:1;justify-content:space-between",
|
|
101
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0MiLCJmaWxlIjoic2V0dGluZ3MtY29udGFpbmVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5cbmNvbnN0IEhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXg6IDE7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XG5cbmNvbnN0IFNldHRpbmdzQ29udGFpbmVyID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cImZsYXRcIiB0aGVtZT17cHJvcHMuY29udGFpbmVyVGhlbWV9PlxuICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhzXCI+XG4gICAgICAgICAgICA8SGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgzXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICA8QWNjZXNzaWJsZUJ1dHRvblxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9e3Byb3BzLm9uQ2xvc2V9XG4gICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxDbG9zZUljb24gc2l6ZT1cIm1lZGl1bVwiIC8+XG4gICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgIDwvSGVhZGVyQ29udGFpbmVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgICAgICAgPFNwYWNpbmdzLkluc2V0IHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgIDxkaXYgc3R5bGU9e2NvbnRhaW5lclN0eWxlc30+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLkluc2V0PlxuICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCI+XG4gICAgICAgICAgICAgICAgICB7cHJvcHMuc2Vjb25kYXJ5QnV0dG9ufVxuICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgIDwvQ2FyZD5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKTtcbn07XG5cblNldHRpbmdzQ29udGFpbmVyLmRpc3BsYXlOYW1lID0gJ1NldHRpbmdzQ29udGFpbmVyJztcblNldHRpbmdzQ29udGFpbmVyLnByb3BUeXBlcyA9IHtcbiAgdGl0bGU6IFByb3BUeXBlcy5zaGFwZSh7XG4gICAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBkZWZhdWx0TWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICB9KS5pc1JlcXVpcmVkLFxuICBjbG9zZUJ1dHRvbkxhYmVsOiBQcm9wVHlwZXMuc2hhcGUoe1xuICAgIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgZGVmYXVsdE1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgfSkuaXNSZXF1aXJlZCxcbiAgb25DbG9zZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgcHJpbWFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIHNlY29uZGFyeUJ1dHRvbjogUHJvcFR5cGVzLmVsZW1lbnQsXG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICBjb250YWluZXJUaGVtZTogUHJvcFR5cGVzLm9uZU9mKFsnbGlnaHQnLCAnZGFyayddKSxcbn07XG5TZXR0aW5nc0NvbnRhaW5lci5kZWZhdWx0UHJvcHMgPSB7XG4gIGNvbnRhaW5lclRoZW1lOiAnZGFyaycsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBTZXR0aW5nc0NvbnRhaW5lcjtcbiJdfQ== */",
|
|
103
102
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
104
103
|
});
|
|
105
104
|
|
|
106
105
|
var SettingsContainer = function SettingsContainer(props) {
|
|
107
106
|
var intl = reactIntl.useIntl();
|
|
108
|
-
return
|
|
109
|
-
isDefaultClosed: false
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
107
|
+
return jsxRuntime.jsx(CollapsibleMotion__default["default"], {
|
|
108
|
+
isDefaultClosed: false,
|
|
109
|
+
children: function children(_ref) {
|
|
110
|
+
var registerContentNode = _ref.registerContentNode,
|
|
111
|
+
containerStyles = _ref.containerStyles;
|
|
112
|
+
return jsxRuntime.jsx(Card__default["default"], {
|
|
113
|
+
type: "flat",
|
|
114
|
+
theme: props.containerTheme,
|
|
115
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
116
|
+
scale: "xs",
|
|
117
|
+
children: [jsxRuntime.jsxs(HeaderContainer, {
|
|
118
|
+
children: [jsxRuntime.jsx(Text__default["default"].Headline, {
|
|
119
|
+
as: "h3",
|
|
120
|
+
intlMessage: props.title
|
|
121
|
+
}), jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
122
|
+
onClick: props.onClose,
|
|
123
|
+
label: intl.formatMessage(props.closeButtonLabel),
|
|
124
|
+
children: jsxRuntime.jsx(icons.CloseIcon, {
|
|
125
|
+
size: "medium"
|
|
126
|
+
})
|
|
127
|
+
})]
|
|
128
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
129
|
+
scale: "xs",
|
|
130
|
+
children: [jsxRuntime.jsx(Spacings__default["default"].Inset, {
|
|
131
|
+
scale: "s",
|
|
132
|
+
children: jsxRuntime.jsx("div", {
|
|
133
|
+
style: containerStyles,
|
|
134
|
+
children: jsxRuntime.jsx("div", {
|
|
135
|
+
ref: registerContentNode,
|
|
136
|
+
children: props.children
|
|
137
|
+
})
|
|
138
|
+
})
|
|
139
|
+
}), (props.secondaryButton || props.primaryButton) && jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
140
|
+
justifyContent: "flex-end",
|
|
141
|
+
children: [props.secondaryButton, props.primaryButton]
|
|
142
|
+
})]
|
|
143
|
+
})]
|
|
144
|
+
})
|
|
145
|
+
});
|
|
146
|
+
}
|
|
137
147
|
});
|
|
138
148
|
};
|
|
139
149
|
|
|
140
150
|
SettingsContainer.displayName = 'SettingsContainer';
|
|
141
151
|
SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
142
|
-
title: PropTypes__default[
|
|
143
|
-
id: PropTypes__default[
|
|
144
|
-
defaultMessage: PropTypes__default[
|
|
152
|
+
title: PropTypes__default["default"].shape({
|
|
153
|
+
id: PropTypes__default["default"].string.isRequired,
|
|
154
|
+
defaultMessage: PropTypes__default["default"].string.isRequired
|
|
145
155
|
}).isRequired,
|
|
146
|
-
closeButtonLabel: PropTypes__default[
|
|
147
|
-
id: PropTypes__default[
|
|
148
|
-
defaultMessage: PropTypes__default[
|
|
156
|
+
closeButtonLabel: PropTypes__default["default"].shape({
|
|
157
|
+
id: PropTypes__default["default"].string.isRequired,
|
|
158
|
+
defaultMessage: PropTypes__default["default"].string.isRequired
|
|
149
159
|
}).isRequired,
|
|
150
|
-
onClose: PropTypes__default[
|
|
151
|
-
primaryButton: PropTypes__default[
|
|
152
|
-
secondaryButton: PropTypes__default[
|
|
153
|
-
children: PropTypes__default[
|
|
154
|
-
containerTheme: PropTypes__default[
|
|
160
|
+
onClose: PropTypes__default["default"].func.isRequired,
|
|
161
|
+
primaryButton: PropTypes__default["default"].element,
|
|
162
|
+
secondaryButton: PropTypes__default["default"].element,
|
|
163
|
+
children: PropTypes__default["default"].node.isRequired,
|
|
164
|
+
containerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
|
|
155
165
|
} : {};
|
|
156
166
|
SettingsContainer.defaultProps = {
|
|
157
167
|
containerTheme: 'dark'
|
|
@@ -210,51 +220,73 @@ var DensityManager = function DensityManager(props) {
|
|
|
210
220
|
var intl = reactIntl.useIntl();
|
|
211
221
|
var textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
212
222
|
var densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_DEFAULT;
|
|
213
|
-
return
|
|
223
|
+
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
214
224
|
title: messages$3.title,
|
|
215
225
|
closeButtonLabel: messages$3.closeButtonLabel,
|
|
216
226
|
onClose: props.onClose,
|
|
217
227
|
primaryButton: props.primaryButton,
|
|
218
228
|
secondaryButton: props.secondaryButton,
|
|
219
|
-
containerTheme: props.managerTheme
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
229
|
+
containerTheme: props.managerTheme,
|
|
230
|
+
children: jsxRuntime.jsxs(Grid__default["default"], {
|
|
231
|
+
gridGap: designSystem.customProperties.spacingM,
|
|
232
|
+
gridTemplateColumns: "repeat(2, 1fr)",
|
|
233
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
234
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
235
|
+
scale: "s",
|
|
236
|
+
children: [jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
237
|
+
title: intl.formatMessage(messages$3.textWrappingSubtitle)
|
|
238
|
+
}), jsxRuntime.jsxs(AccessibleHiden__default["default"], {
|
|
239
|
+
children: [jsxRuntime.jsx("label", {
|
|
240
|
+
htmlFor: "text-wrapping-0",
|
|
241
|
+
children: "Select radio option: display full text"
|
|
242
|
+
}), jsxRuntime.jsx("label", {
|
|
243
|
+
htmlFor: "text-wrapping-1",
|
|
244
|
+
children: "Select radio option: display full previews"
|
|
245
|
+
})]
|
|
246
|
+
}), jsxRuntime.jsxs(RadioInput__default["default"].Group, {
|
|
247
|
+
id: "text-wrapping",
|
|
248
|
+
name: "text-wrapping",
|
|
249
|
+
value: textWrappingOption,
|
|
250
|
+
onChange: props.onTextWrappingChange,
|
|
251
|
+
children: [jsxRuntime.jsx(RadioInput__default["default"].Option, {
|
|
252
|
+
value: WRAPPED_TEXT_VISIBLE,
|
|
253
|
+
children: intl.formatMessage(messages$3.textWrappingAllWrapVisibleOption)
|
|
254
|
+
}), jsxRuntime.jsx(RadioInput__default["default"].Option, {
|
|
255
|
+
value: SHOW_HIDE_ON_DEMAND,
|
|
256
|
+
children: intl.formatMessage(messages$3.textWrappingShowHideOnDemandOption)
|
|
257
|
+
})]
|
|
258
|
+
})]
|
|
259
|
+
})
|
|
260
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
261
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
262
|
+
scale: "s",
|
|
263
|
+
children: [jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
264
|
+
title: intl.formatMessage(messages$3.densityDisplaySubtitle)
|
|
265
|
+
}), jsxRuntime.jsxs(AccessibleHiden__default["default"], {
|
|
266
|
+
children: [jsxRuntime.jsx("label", {
|
|
267
|
+
htmlFor: "density-display-0",
|
|
268
|
+
children: "Select radio option: density default"
|
|
269
|
+
}), jsxRuntime.jsx("label", {
|
|
270
|
+
htmlFor: "density-display-1",
|
|
271
|
+
children: "Select radio option: density compact"
|
|
272
|
+
})]
|
|
273
|
+
}), jsxRuntime.jsxs(RadioInput__default["default"].Group, {
|
|
274
|
+
id: "density-display",
|
|
275
|
+
name: "density-display",
|
|
276
|
+
value: densityDisplayOption,
|
|
277
|
+
onChange: props.onDensityDisplayChange,
|
|
278
|
+
children: [jsxRuntime.jsx(RadioInput__default["default"].Option, {
|
|
279
|
+
value: DENSITY_DEFAULT,
|
|
280
|
+
children: intl.formatMessage(messages$3.densityDisplayDefaultOption)
|
|
281
|
+
}), jsxRuntime.jsx(RadioInput__default["default"].Option, {
|
|
282
|
+
value: DENSITY_COMPACT,
|
|
283
|
+
children: intl.formatMessage(messages$3.densityDisplayCompactOption)
|
|
284
|
+
})]
|
|
285
|
+
})]
|
|
286
|
+
})
|
|
287
|
+
})]
|
|
288
|
+
})
|
|
289
|
+
});
|
|
258
290
|
};
|
|
259
291
|
|
|
260
292
|
DensityManager.displayName = 'DensityManager';
|
|
@@ -263,20 +295,20 @@ DensityManager.defaultProps = {
|
|
|
263
295
|
isWrappingText: false
|
|
264
296
|
};
|
|
265
297
|
DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
266
|
-
isCondensed: PropTypes__default[
|
|
267
|
-
isWrappingText: PropTypes__default[
|
|
268
|
-
primaryButton: PropTypes__default[
|
|
269
|
-
secondaryButton: PropTypes__default[
|
|
270
|
-
onDensityDisplayChange: PropTypes__default[
|
|
271
|
-
onTextWrappingChange: PropTypes__default[
|
|
272
|
-
onClose: PropTypes__default[
|
|
273
|
-
managerTheme: PropTypes__default[
|
|
298
|
+
isCondensed: PropTypes__default["default"].bool,
|
|
299
|
+
isWrappingText: PropTypes__default["default"].bool,
|
|
300
|
+
primaryButton: PropTypes__default["default"].element,
|
|
301
|
+
secondaryButton: PropTypes__default["default"].element,
|
|
302
|
+
onDensityDisplayChange: PropTypes__default["default"].func.isRequired,
|
|
303
|
+
onTextWrappingChange: PropTypes__default["default"].func.isRequired,
|
|
304
|
+
onClose: PropTypes__default["default"].func.isRequired,
|
|
305
|
+
managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
|
|
274
306
|
} : {};
|
|
275
307
|
var DisplaySettingsManager = DensityManager;
|
|
276
308
|
|
|
277
309
|
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)."; }
|
|
278
310
|
|
|
279
|
-
var DraggingSmall = _styled__default[
|
|
311
|
+
var DraggingSmall = _styled__default["default"]("small", process.env.NODE_ENV === "production" ? {
|
|
280
312
|
target: "ed3a5rx1"
|
|
281
313
|
} : {
|
|
282
314
|
target: "ed3a5rx1",
|
|
@@ -287,62 +319,73 @@ var DraggingSmall = _styled__default['default']("small", process.env.NODE_ENV ==
|
|
|
287
319
|
} : {
|
|
288
320
|
name: "1fhyj3b",
|
|
289
321
|
styles: "&:hover{cursor:grab;}",
|
|
322
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVrQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */",
|
|
290
323
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
291
324
|
});
|
|
292
325
|
|
|
293
|
-
var DraggingContainer = _styled__default[
|
|
326
|
+
var DraggingContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
294
327
|
target: "ed3a5rx0"
|
|
295
328
|
} : {
|
|
296
329
|
target: "ed3a5rx0",
|
|
297
330
|
label: "DraggingContainer"
|
|
298
|
-
})(DraggingSmall, ";");
|
|
331
|
+
})(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFvQyIsImZpbGUiOiJkcmFnZ2FibGUtdGFnLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgRHJhZ2dpbmdTbWFsbCA9IHN0eWxlZC5zbWFsbGBcbiAgJjpob3ZlciB7XG4gICAgY3Vyc29yOiBncmFiO1xuICB9XG5gO1xuXG5jb25zdCBEcmFnZ2luZ0NvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gICR7RHJhZ2dpbmdTbWFsbH07XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBEcmFnZ2luZ0NvbnRhaW5lcjtcbiJdfQ== */"));
|
|
299
332
|
|
|
300
333
|
var DraggingContainer$1 = DraggingContainer;
|
|
301
334
|
|
|
335
|
+
function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (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; }
|
|
336
|
+
|
|
337
|
+
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__default["default"](_context = ownKeys$3(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context2; _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; }
|
|
338
|
+
|
|
302
339
|
var DraggableTag = function DraggableTag(props) {
|
|
303
340
|
var handleRemoveColumn = function handleRemoveColumn() {
|
|
304
341
|
return props.onRemove(props.index);
|
|
305
342
|
};
|
|
306
343
|
|
|
307
|
-
return
|
|
344
|
+
return jsxRuntime.jsx(reactBeautifulDnd.Draggable, {
|
|
308
345
|
draggableId: props.column.key,
|
|
309
346
|
index: props.index,
|
|
310
|
-
isDragDisabled: props.isDisabled
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
347
|
+
isDragDisabled: props.isDisabled,
|
|
348
|
+
children: function children(provided) {
|
|
349
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Inset, {
|
|
350
|
+
scale: "xs",
|
|
351
|
+
children: [jsxRuntime.jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
|
|
352
|
+
ref: provided.innerRef
|
|
353
|
+
}, provided.draggableProps), provided.dragHandleProps), {}, {
|
|
354
|
+
children: jsxRuntime.jsx(Tag__default["default"], {
|
|
355
|
+
onRemove: props.onRemove ? handleRemoveColumn : undefined,
|
|
356
|
+
isDisabled: props.isDisabled,
|
|
357
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
358
|
+
alignItems: "center",
|
|
359
|
+
children: [jsxRuntime.jsx(icons.DragIcon, {
|
|
360
|
+
"data-testid": "drag-icon",
|
|
361
|
+
size: "medium"
|
|
362
|
+
}), props.column.label]
|
|
363
|
+
})
|
|
364
|
+
})
|
|
365
|
+
})), provided.placeholder]
|
|
366
|
+
});
|
|
367
|
+
}
|
|
325
368
|
});
|
|
326
369
|
};
|
|
327
370
|
|
|
328
371
|
DraggableTag.displayName = 'DraggableTag';
|
|
329
372
|
DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
330
|
-
column: PropTypes__default[
|
|
331
|
-
key: PropTypes__default[
|
|
332
|
-
label: PropTypes__default[
|
|
373
|
+
column: PropTypes__default["default"].shape({
|
|
374
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
375
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
333
376
|
}).isRequired,
|
|
334
|
-
index: PropTypes__default[
|
|
335
|
-
onRemove: PropTypes__default[
|
|
336
|
-
isDisabled: PropTypes__default[
|
|
377
|
+
index: PropTypes__default["default"].number.isRequired,
|
|
378
|
+
onRemove: PropTypes__default["default"].func,
|
|
379
|
+
isDisabled: PropTypes__default["default"].bool
|
|
337
380
|
} : {};
|
|
338
381
|
var DraggableTag$1 = DraggableTag;
|
|
339
382
|
|
|
340
|
-
var TagContainerEditable = _styled__default[
|
|
383
|
+
var TagContainerEditable = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
341
384
|
target: "ecy2q1d0"
|
|
342
385
|
} : {
|
|
343
386
|
target: "ecy2q1d0",
|
|
344
387
|
label: "TagContainerEditable"
|
|
345
|
-
})("background-color:", designSystem.customProperties.backgroundColorForInput, ";border:", designSystem.customProperties.borderRadius1, " solid ", designSystem.customProperties.colorNeutral60, ";border-radius:", designSystem.customProperties.borderRadius6, ";padding:", designSystem.customProperties.spacingS, ";height:", designSystem.customProperties.constraint7, ";overflow:auto;");
|
|
388
|
+
})("background-color:", designSystem.customProperties.backgroundColorForInput, ";border:", designSystem.customProperties.borderRadius1, " solid ", designSystem.customProperties.colorNeutral60, ";border-radius:", designSystem.customProperties.borderRadius6, ";padding:", designSystem.customProperties.spacingS, ";height:", designSystem.customProperties.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR3VDIiwiZmlsZSI6InRhZy1jb250YWluZXItZWRpdGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgVGFnQ29udGFpbmVyRWRpdGFibGUgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXR9O1xuICBib3JkZXI6ICR7dmFycy5ib3JkZXJSYWRpdXMxfSBzb2xpZCAke3ZhcnMuY29sb3JOZXV0cmFsNjB9O1xuICBib3JkZXItcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzNn07XG4gIHBhZGRpbmc6ICR7dmFycy5zcGFjaW5nU307XG4gIGhlaWdodDogJHt2YXJzLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
|
|
346
389
|
|
|
347
390
|
var TagContainerEditable$1 = TagContainerEditable;
|
|
348
391
|
|
|
@@ -355,52 +398,58 @@ var messages$2 = reactIntl.defineMessages({
|
|
|
355
398
|
});
|
|
356
399
|
|
|
357
400
|
var DroppablePanel = function DroppablePanel(props) {
|
|
358
|
-
return
|
|
359
|
-
droppableId: props.droppableId
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
401
|
+
return jsxRuntime.jsx(reactBeautifulDnd.Droppable, {
|
|
402
|
+
droppableId: props.droppableId,
|
|
403
|
+
children: function children(provided) {
|
|
404
|
+
var _context;
|
|
405
|
+
|
|
406
|
+
return jsxRuntime.jsxs(TagContainerEditable$1, {
|
|
407
|
+
"data-testid": props.droppableId,
|
|
408
|
+
ref: provided.innerRef,
|
|
409
|
+
children: [props.columns.length === 0 ? jsxRuntime.jsx(Spacings__default["default"].Inset, {
|
|
410
|
+
scale: "s",
|
|
411
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
412
|
+
tone: "secondary",
|
|
413
|
+
children: props.noColumnsText
|
|
414
|
+
})
|
|
415
|
+
}) : jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
416
|
+
children: [_mapInstanceProperty__default["default"](_context = props.columns).call(_context, function (column, index) {
|
|
417
|
+
var _context2;
|
|
418
|
+
|
|
419
|
+
return jsxRuntime.jsx(DraggableTag$1, {
|
|
420
|
+
column: column,
|
|
421
|
+
index: index,
|
|
422
|
+
onRemove: props.onRemove ? function () {
|
|
423
|
+
var _context3, _context4, _context5;
|
|
424
|
+
|
|
425
|
+
return props.onRemove(_concatInstanceProperty__default["default"](_context3 = []).call(_context3, _toConsumableArray(_sliceInstanceProperty__default["default"](_context4 = props.columns).call(_context4, 0, index)), _toConsumableArray(_sliceInstanceProperty__default["default"](_context5 = props.columns).call(_context5, index + 1))));
|
|
426
|
+
} : undefined,
|
|
427
|
+
isDisabled: props.isDisabled
|
|
428
|
+
}, _concatInstanceProperty__default["default"](_context2 = "".concat(column.key, "-")).call(_context2, index));
|
|
429
|
+
}), props.isSearchable && jsxRuntime.jsx(Spacings__default["default"].Inset, {
|
|
430
|
+
scale: "xs",
|
|
431
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
432
|
+
tone: "secondary",
|
|
433
|
+
intlMessage: messages$2.loadMoreAttributesHint
|
|
434
|
+
})
|
|
435
|
+
})]
|
|
436
|
+
}), provided.placeholder]
|
|
383
437
|
});
|
|
384
|
-
}
|
|
385
|
-
scale: "xs"
|
|
386
|
-
}, react.jsx(Text__default['default'].Detail, {
|
|
387
|
-
tone: "secondary",
|
|
388
|
-
intlMessage: messages$2.loadMoreAttributesHint
|
|
389
|
-
}))), provided.placeholder);
|
|
438
|
+
}
|
|
390
439
|
});
|
|
391
440
|
};
|
|
392
441
|
|
|
393
442
|
DroppablePanel.displayName = 'DroppablePanel';
|
|
394
443
|
DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
395
|
-
droppableId: PropTypes__default[
|
|
396
|
-
noColumnsText: PropTypes__default[
|
|
397
|
-
columns: PropTypes__default[
|
|
398
|
-
key: PropTypes__default[
|
|
399
|
-
label: PropTypes__default[
|
|
444
|
+
droppableId: PropTypes__default["default"].string.isRequired,
|
|
445
|
+
noColumnsText: PropTypes__default["default"].node.isRequired,
|
|
446
|
+
columns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
447
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
448
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
400
449
|
})),
|
|
401
|
-
isSearchable: PropTypes__default[
|
|
402
|
-
isDisabled: PropTypes__default[
|
|
403
|
-
onRemove: PropTypes__default[
|
|
450
|
+
isSearchable: PropTypes__default["default"].bool,
|
|
451
|
+
isDisabled: PropTypes__default["default"].bool,
|
|
452
|
+
onRemove: PropTypes__default["default"].func
|
|
404
453
|
} : {};
|
|
405
454
|
var DroppablePanel$1 = DroppablePanel;
|
|
406
455
|
|
|
@@ -440,14 +489,18 @@ var messages$1 = reactIntl.defineMessages({
|
|
|
440
489
|
var HIDDEN_COLUMNS_PANEL = 'hidden-columns-panel';
|
|
441
490
|
var SELECTED_COLUMNS_PANEL = 'selected-columns-panel';
|
|
442
491
|
|
|
443
|
-
var
|
|
492
|
+
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (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; }
|
|
493
|
+
|
|
494
|
+
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__default["default"](_context4 = ownKeys$2(Object(source), true)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context5; _forEachInstanceProperty__default["default"](_context5 = ownKeys$2(Object(source))).call(_context5, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
|
|
495
|
+
|
|
496
|
+
var DroppableContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
444
497
|
target: "e6ge22w0"
|
|
445
498
|
} : {
|
|
446
499
|
target: "e6ge22w0",
|
|
447
500
|
label: "DroppableContainer"
|
|
448
501
|
})("width:100%;position:relative;max-width:", designSystem.customProperties.constraint10, ";cursor:", function (props) {
|
|
449
502
|
return props.isDragging ? 'grabbing' : 'auto';
|
|
450
|
-
}, ";");
|
|
503
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.js"],"names":[],"mappings":"AAsBqC","file":"column-settings-manager.js","sourcesContent":["import { useMemo, useCallback, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\nconst DroppableContainer = styled.div`\n  width: 100%;\n  position: relative;\n  max-width: ${vars.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult,\n  onUpdateColumns,\n  selectedColumns,\n  availableColumns,\n  setIsDragging\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position\n    onUpdateColumns([\n      ...items.slice(0, dragResult.destination.index),\n      draggedColumn,\n      ...items.slice(dragResult.destination.index),\n    ]);\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon scale=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props) => {\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const handleInputChange = useCallback(\n    (input) =>\n      // loadOptions is not invoked when input is empty\n      !input.length && searchHiddenColumns(input),\n    [searchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"m\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  cacheOptions={false}\n                  onChange={() => {\n                    // to avoid prop-types error\n                    // as `onChange` is a required prop in\n                    // `AsyncSelectInput`\n                  }}\n                  // loadOptions is used instead of onInputChange\n                  // because the loading indicator is displayed\n                  // only when loadOptions is invoked\n                  loadOptions={debounce(searchHiddenColumns, 300)}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack>\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nColumnSettingsManager.propTypes = {\n  availableColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  selectedColumns: PropTypes.arrayOf(\n    PropTypes.shape({\n      key: PropTypes.string.isRequired,\n      label: PropTypes.oneOfType([PropTypes.string, PropTypes.node]).isRequired,\n    })\n  ).isRequired,\n  onUpdateColumns: PropTypes.func.isRequired,\n\n  areHiddenColumnsSearchable: PropTypes.bool,\n  searchHiddenColumns: requiredIf(\n    PropTypes.func,\n    (props) => props.areHiddenColumnsSearchable\n  ),\n  searchHiddenColumnsPlaceholder: PropTypes.string,\n\n  onClose: PropTypes.func,\n  primaryButton: PropTypes.element,\n  secondaryButton: PropTypes.element,\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nColumnSettingsManager.defaultProps = {\n  availableColumns: [],\n};\n\nexport default ColumnSettingsManager;\n"]} */"));
|
|
451
504
|
|
|
452
505
|
var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) {
|
|
453
506
|
setIsDragging(false); // Invalid drop destination, do nothing
|
|
@@ -458,7 +511,7 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
|
|
|
458
511
|
var _context;
|
|
459
512
|
|
|
460
513
|
if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
|
|
461
|
-
onUpdateColumns(_concatInstanceProperty__default[
|
|
514
|
+
onUpdateColumns(_concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, 0, dragResult.source.index)), _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, dragResult.source.index + 1))));
|
|
462
515
|
} else {
|
|
463
516
|
var _context2, _context3;
|
|
464
517
|
|
|
@@ -467,25 +520,26 @@ var handleColumnsUpdate = function handleColumnsUpdate(dragResult, onUpdateColum
|
|
|
467
520
|
var isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
|
|
468
521
|
var items = isSwap ? // remove the dragged item from its position if it is not coming from
|
|
469
522
|
// the hidden section (it is a swap)
|
|
470
|
-
_concatInstanceProperty__default[
|
|
523
|
+
_concatInstanceProperty__default["default"](_context2 = []).call(_context2, _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, 0, dragResult.source.index)), _toConsumableArray(_sliceInstanceProperty__default["default"](selectedColumns).call(selectedColumns, dragResult.source.index + 1))) : selectedColumns;
|
|
471
524
|
var columns = isSwap ? selectedColumns : availableColumns;
|
|
472
525
|
|
|
473
|
-
var draggedColumn = _findInstanceProperty__default[
|
|
526
|
+
var draggedColumn = _findInstanceProperty__default["default"](columns).call(columns, function (col) {
|
|
474
527
|
return col.key === dragResult.draggableId;
|
|
475
528
|
}); // push the column in the new position
|
|
476
529
|
|
|
477
530
|
|
|
478
|
-
onUpdateColumns(_concatInstanceProperty__default[
|
|
531
|
+
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))));
|
|
479
532
|
}
|
|
480
533
|
};
|
|
481
534
|
|
|
482
535
|
var DropdownIndicator = function DropdownIndicator() {
|
|
483
|
-
return
|
|
484
|
-
alignItems: "center"
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
536
|
+
return jsxRuntime.jsx(Spacings__default["default"].Inline, {
|
|
537
|
+
alignItems: "center",
|
|
538
|
+
children: jsxRuntime.jsx(icons.SearchIcon, {
|
|
539
|
+
scale: "medium",
|
|
540
|
+
color: "primary"
|
|
541
|
+
})
|
|
542
|
+
});
|
|
489
543
|
};
|
|
490
544
|
|
|
491
545
|
DropdownIndicator.displayName = 'DropdownIndicator';
|
|
@@ -502,7 +556,7 @@ var selectInputComponents = {
|
|
|
502
556
|
var ColumnSettingsManager = function ColumnSettingsManager(props) {
|
|
503
557
|
var intl = reactIntl.useIntl();
|
|
504
558
|
|
|
505
|
-
var _useState =
|
|
559
|
+
var _useState = react.useState(false),
|
|
506
560
|
_useState2 = _slicedToArray(_useState, 2),
|
|
507
561
|
isDragging = _useState2[0],
|
|
508
562
|
setIsDragging = _useState2[1];
|
|
@@ -513,101 +567,112 @@ var ColumnSettingsManager = function ColumnSettingsManager(props) {
|
|
|
513
567
|
setIsDragging(true);
|
|
514
568
|
};
|
|
515
569
|
|
|
516
|
-
var hiddenColumns =
|
|
517
|
-
return differenceWith__default[
|
|
570
|
+
var hiddenColumns = react.useMemo(function () {
|
|
571
|
+
return differenceWith__default["default"](props.availableColumns, props.selectedColumns, function (a, b) {
|
|
518
572
|
return a.key === b.key;
|
|
519
573
|
});
|
|
520
574
|
}, [props.availableColumns, props.selectedColumns]);
|
|
521
|
-
var handleDragEnd =
|
|
575
|
+
var handleDragEnd = react.useCallback(function (dragResult) {
|
|
522
576
|
return handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging);
|
|
523
577
|
}, [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
524
|
-
var handleInputChange =
|
|
578
|
+
var handleInputChange = react.useCallback(function (input) {
|
|
525
579
|
return (// loadOptions is not invoked when input is empty
|
|
526
580
|
!input.length && searchHiddenColumns(input)
|
|
527
581
|
);
|
|
528
582
|
}, [searchHiddenColumns]);
|
|
529
|
-
return
|
|
583
|
+
return jsxRuntime.jsx(SettingsContainer$1, {
|
|
530
584
|
title: messages$1.title,
|
|
531
585
|
closeButtonLabel: messages$1.closeButtonLabel,
|
|
532
586
|
onClose: props.onClose,
|
|
533
587
|
primaryButton: props.primaryButton,
|
|
534
588
|
secondaryButton: props.secondaryButton,
|
|
535
|
-
containerTheme: props.managerTheme
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
589
|
+
containerTheme: props.managerTheme,
|
|
590
|
+
children: jsxRuntime.jsx(reactBeautifulDnd.DragDropContext, {
|
|
591
|
+
onDragEnd: handleDragEnd,
|
|
592
|
+
onDragStart: handleDragStart,
|
|
593
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
594
|
+
scale: "m",
|
|
595
|
+
children: [jsxRuntime.jsx(DroppableContainer, {
|
|
596
|
+
isDragging: isDragging,
|
|
597
|
+
"aria-labelledby": "hidden-columns",
|
|
598
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
599
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
600
|
+
scale: "xs",
|
|
601
|
+
alignItems: "center",
|
|
602
|
+
children: [jsxRuntime.jsx(icons.EyeCrossedIcon, {
|
|
603
|
+
size: "medium"
|
|
604
|
+
}), jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
605
|
+
id: "hidden-columns",
|
|
606
|
+
title: intl.formatMessage(messages$1.hiddenColumns)
|
|
607
|
+
})]
|
|
608
|
+
}), props.areHiddenColumnsSearchable && jsxRuntime.jsx(AsyncSelectInput__default["default"], _objectSpread$2(_objectSpread$2({}, props.searchHiddenColumnsPlaceholder ? {
|
|
609
|
+
placeholder: props.searchHiddenColumnsPlaceholder
|
|
610
|
+
} : undefined), {}, {
|
|
611
|
+
cacheOptions: false,
|
|
612
|
+
onChange: function onChange() {// to avoid prop-types error
|
|
613
|
+
// as `onChange` is a required prop in
|
|
614
|
+
// `AsyncSelectInput`
|
|
615
|
+
} // loadOptions is used instead of onInputChange
|
|
616
|
+
// because the loading indicator is displayed
|
|
617
|
+
// only when loadOptions is invoked
|
|
618
|
+
,
|
|
619
|
+
loadOptions: debounce__default["default"](searchHiddenColumns, 300),
|
|
620
|
+
onInputChange: handleInputChange,
|
|
621
|
+
components: selectInputComponents
|
|
622
|
+
})), jsxRuntime.jsx(DroppablePanel$1, {
|
|
623
|
+
droppableId: HIDDEN_COLUMNS_PANEL,
|
|
624
|
+
"data-testid": HIDDEN_COLUMNS_PANEL,
|
|
625
|
+
noColumnsText: intl.formatMessage(messages$1.noHiddenColumnsToShow),
|
|
626
|
+
columns: hiddenColumns,
|
|
627
|
+
isSearchable: props.areHiddenColumnsSearchable
|
|
628
|
+
})]
|
|
629
|
+
})
|
|
630
|
+
}), jsxRuntime.jsx(DroppableContainer, {
|
|
631
|
+
isDragging: isDragging,
|
|
632
|
+
"aria-labelledby": "visible-columns",
|
|
633
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
634
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
635
|
+
scale: "xs",
|
|
636
|
+
alignItems: "center",
|
|
637
|
+
children: [jsxRuntime.jsx(icons.EyeIcon, {
|
|
638
|
+
size: "medium"
|
|
639
|
+
}), jsxRuntime.jsx(FieldLabel__default["default"], {
|
|
640
|
+
id: "visible-columns",
|
|
641
|
+
title: intl.formatMessage(messages$1.visibleColumns)
|
|
642
|
+
})]
|
|
643
|
+
}), jsxRuntime.jsx(DroppablePanel$1, {
|
|
644
|
+
droppableId: SELECTED_COLUMNS_PANEL,
|
|
645
|
+
"data-testid": SELECTED_COLUMNS_PANEL,
|
|
646
|
+
noColumnsText: intl.formatMessage(messages$1.noSelectedColumnsToShow),
|
|
647
|
+
columns: props.selectedColumns,
|
|
648
|
+
onRemove: props.onUpdateColumns
|
|
649
|
+
})]
|
|
650
|
+
})
|
|
651
|
+
})]
|
|
652
|
+
})
|
|
653
|
+
})
|
|
654
|
+
});
|
|
590
655
|
};
|
|
591
656
|
ColumnSettingsManager.displayName = 'ColumnSettingsManager';
|
|
592
657
|
ColumnSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
593
|
-
availableColumns: PropTypes__default[
|
|
594
|
-
key: PropTypes__default[
|
|
595
|
-
label: PropTypes__default[
|
|
658
|
+
availableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
659
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
660
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
596
661
|
})).isRequired,
|
|
597
|
-
selectedColumns: PropTypes__default[
|
|
598
|
-
key: PropTypes__default[
|
|
599
|
-
label: PropTypes__default[
|
|
662
|
+
selectedColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
663
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
664
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
600
665
|
})).isRequired,
|
|
601
|
-
onUpdateColumns: PropTypes__default[
|
|
602
|
-
areHiddenColumnsSearchable: PropTypes__default[
|
|
603
|
-
searchHiddenColumns: requiredIf__default[
|
|
666
|
+
onUpdateColumns: PropTypes__default["default"].func.isRequired,
|
|
667
|
+
areHiddenColumnsSearchable: PropTypes__default["default"].bool,
|
|
668
|
+
searchHiddenColumns: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
|
|
604
669
|
return props.areHiddenColumnsSearchable;
|
|
605
670
|
}),
|
|
606
|
-
searchHiddenColumnsPlaceholder: PropTypes__default[
|
|
607
|
-
onClose: PropTypes__default[
|
|
608
|
-
primaryButton: PropTypes__default[
|
|
609
|
-
secondaryButton: PropTypes__default[
|
|
610
|
-
managerTheme: PropTypes__default[
|
|
671
|
+
searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
|
|
672
|
+
onClose: PropTypes__default["default"].func,
|
|
673
|
+
primaryButton: PropTypes__default["default"].element,
|
|
674
|
+
secondaryButton: PropTypes__default["default"].element,
|
|
675
|
+
managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
|
|
611
676
|
} : {};
|
|
612
677
|
ColumnSettingsManager.defaultProps = {
|
|
613
678
|
availableColumns: []
|
|
@@ -632,22 +697,20 @@ var messages = reactIntl.defineMessages({
|
|
|
632
697
|
}
|
|
633
698
|
});
|
|
634
699
|
|
|
635
|
-
var
|
|
636
|
-
|
|
637
|
-
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default['default'](object); if (_Object$getOwnPropertySymbols__default['default']) { var symbols = _Object$getOwnPropertySymbols__default['default'](object); if (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; }
|
|
700
|
+
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (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; }
|
|
638
701
|
|
|
639
|
-
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__default[
|
|
702
|
+
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__default["default"](_context2 = ownKeys$1(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context3; _forEachInstanceProperty__default["default"](_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
|
|
640
703
|
|
|
641
704
|
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)."; }
|
|
642
705
|
|
|
643
|
-
var SelectContainer = _styled__default[
|
|
706
|
+
var SelectContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
644
707
|
target: "eh8k7x01"
|
|
645
708
|
} : {
|
|
646
709
|
target: "eh8k7x01",
|
|
647
710
|
label: "SelectContainer"
|
|
648
|
-
})("width:", designSystem.customProperties.constraint4, ";");
|
|
711
|
+
})("width:", designSystem.customProperties.constraint4, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAqBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager.hideableColumns}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */"));
|
|
649
712
|
|
|
650
|
-
var TopBarContainer = _styled__default[
|
|
713
|
+
var TopBarContainer = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
651
714
|
target: "eh8k7x00"
|
|
652
715
|
} : {
|
|
653
716
|
target: "eh8k7x00",
|
|
@@ -658,6 +721,7 @@ var TopBarContainer = _styled__default['default']("div", process.env.NODE_ENV ==
|
|
|
658
721
|
} : {
|
|
659
722
|
name: "1ff36h2",
|
|
660
723
|
styles: "flex-grow:1",
|
|
724
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.js"],"names":[],"mappings":"AAyBkC","file":"data-table-settings.js","sourcesContent":["import PropTypes from 'prop-types';\nimport { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl } from 'react-intl';\nimport styled from '@emotion/styled';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport { TableIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { UPDATE_ACTIONS, COLUMN_MANAGER, DISPLAY_SETTINGS } from '../constants';\nimport DisplaySettingsManager, {\n  DENSITY_COMPACT,\n  SHOW_HIDE_ON_DEMAND,\n} from '../display-settings-manager';\nimport ColumnSettingsManager from '../column-settings-manager';\nimport messages from './messages';\n\n/* The horizontal constraint is set on this container instead of the SelectInput\nbecause the input is always empty, and therefore doesn't take any space by itself\nbut we want to keep enough space for the placeholder to be readable */\nconst SelectContainer = styled.div`\n  width: ${customProperties.constraint4};\n`;\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns = []) =>\n  columns.reduce(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (mappedColumns, visibleColumnsKeys = []) =>\n  visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState(null);\n\n  const dropdownOptions = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const handleDropdownChange = (event) => setOpenedPanelId(event.target.value);\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled ? props.columnManager.visibleColumnKeys : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack>\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <SelectContainer>\n            <AccessibleHidden>\n              <label htmlFor=\"table-settings-dropdown\">\n                Open table manager dropdown\n              </label>\n            </AccessibleHidden>\n            <SelectInput\n              id=\"table-settings-dropdown\"\n              // the dropdown always shows the placeholder as selecting an option\n              // will open the corresponding panel (column manager or display settings)\n              value=\"\"\n              placeholder={intl.formatMessage(messages.placeholder)}\n              onChange={handleDropdownChange}\n              options={dropdownOptions}\n              iconLeft={<TableIcon />}\n            />\n          </SelectContainer>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          onClose={handleSettingsPanelChange}\n          onDensityDisplayChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE,\n              event.target.value === DENSITY_COMPACT\n            );\n          }}\n          onTextWrappingChange={(event) => {\n            props.onSettingsChange(\n              UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE,\n              event.target.value === SHOW_HIDE_ON_DEMAND\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n\n      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager.hideableColumns}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\nDataTableSettings.propTypes = {\n  topBar: PropTypes.node,\n  onSettingsChange: PropTypes.func,\n  displaySettings: PropTypes.shape({\n    disableDisplaySettings: PropTypes.bool,\n    isCondensed: PropTypes.bool,\n    isWrappingText: PropTypes.bool,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  columnManager: PropTypes.shape({\n    areHiddenColumnsSearchable: PropTypes.bool,\n    disableColumnManager: PropTypes.bool,\n    visibleColumnKeys: PropTypes.arrayOf(PropTypes.string.isRequired),\n    hideableColumns: PropTypes.arrayOf(\n      PropTypes.shape({\n        key: PropTypes.string.isRequired,\n        label: PropTypes.oneOfType([PropTypes.string, PropTypes.node])\n          .isRequired,\n      })\n    ),\n    searchHiddenColumns: PropTypes.func,\n    searchHiddenColumnsPlaceholder: PropTypes.string,\n    primaryButton: PropTypes.element,\n    secondaryButton: PropTypes.element,\n  }),\n  managerTheme: PropTypes.oneOf(['light', 'dark']),\n};\n\nexport default DataTableSettings;\n"]} */",
|
|
661
725
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
662
726
|
});
|
|
663
727
|
|
|
@@ -667,7 +731,7 @@ var getDropdownOptions = function getDropdownOptions(_ref) {
|
|
|
667
731
|
var areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
668
732
|
areDisplaySettingsEnabled = _ref.areDisplaySettingsEnabled,
|
|
669
733
|
formatMessage = _ref.formatMessage;
|
|
670
|
-
return _concatInstanceProperty__default[
|
|
734
|
+
return _concatInstanceProperty__default["default"](_context = []).call(_context, _toConsumableArray(areColumnSettingsEnabled ? [{
|
|
671
735
|
value: COLUMN_MANAGER,
|
|
672
736
|
label: formatMessage(messages.columnManagerOption)
|
|
673
737
|
}] : []), _toConsumableArray(areDisplaySettingsEnabled ? [{
|
|
@@ -677,13 +741,13 @@ var getDropdownOptions = function getDropdownOptions(_ref) {
|
|
|
677
741
|
};
|
|
678
742
|
var getMappedColumns = function getMappedColumns() {
|
|
679
743
|
var columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
680
|
-
return _reduceInstanceProperty__default[
|
|
744
|
+
return _reduceInstanceProperty__default["default"](columns).call(columns, function (mappedColumns, column) {
|
|
681
745
|
return _objectSpread$1(_objectSpread$1({}, mappedColumns), {}, _defineProperty({}, column.key, column));
|
|
682
746
|
}, {});
|
|
683
747
|
};
|
|
684
748
|
var getSelectedColumns = function getSelectedColumns(mappedColumns) {
|
|
685
749
|
var visibleColumnsKeys = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
686
|
-
return _mapInstanceProperty__default[
|
|
750
|
+
return _mapInstanceProperty__default["default"](visibleColumnsKeys).call(visibleColumnsKeys, function (columnKey) {
|
|
687
751
|
return mappedColumns[columnKey];
|
|
688
752
|
});
|
|
689
753
|
};
|
|
@@ -694,7 +758,7 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
694
758
|
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;
|
|
695
759
|
var intl = reactIntl.useIntl();
|
|
696
760
|
|
|
697
|
-
var _useState =
|
|
761
|
+
var _useState = react.useState(null),
|
|
698
762
|
_useState2 = _slicedToArray(_useState, 2),
|
|
699
763
|
openedPanelId = _useState2[0],
|
|
700
764
|
setOpenedPanelId = _useState2[1];
|
|
@@ -716,94 +780,110 @@ var DataTableSettings = function DataTableSettings(props) {
|
|
|
716
780
|
return setOpenedPanelId(null);
|
|
717
781
|
};
|
|
718
782
|
|
|
719
|
-
return
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
}
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
783
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
784
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
785
|
+
justifyContent: "space-between",
|
|
786
|
+
alignItems: "center",
|
|
787
|
+
children: [jsxRuntime.jsx(TopBarContainer, {
|
|
788
|
+
children: props.topBar
|
|
789
|
+
}), dropdownOptions.length > 0 && jsxRuntime.jsxs(SelectContainer, {
|
|
790
|
+
children: [jsxRuntime.jsx(AccessibleHiden__default["default"], {
|
|
791
|
+
children: jsxRuntime.jsx("label", {
|
|
792
|
+
htmlFor: "table-settings-dropdown",
|
|
793
|
+
children: "Open table manager dropdown"
|
|
794
|
+
})
|
|
795
|
+
}), jsxRuntime.jsx(SelectInput__default["default"], {
|
|
796
|
+
id: "table-settings-dropdown" // the dropdown always shows the placeholder as selecting an option
|
|
797
|
+
// will open the corresponding panel (column manager or display settings)
|
|
798
|
+
,
|
|
799
|
+
value: "",
|
|
800
|
+
placeholder: intl.formatMessage(messages.placeholder),
|
|
801
|
+
onChange: handleDropdownChange,
|
|
802
|
+
options: dropdownOptions,
|
|
803
|
+
iconLeft: jsxRuntime.jsx(icons.TableIcon, {})
|
|
804
|
+
})]
|
|
805
|
+
})]
|
|
806
|
+
}), openedPanelId === DISPLAY_SETTINGS && jsxRuntime.jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
|
|
807
|
+
onClose: handleSettingsPanelChange,
|
|
808
|
+
onDensityDisplayChange: function onDensityDisplayChange(event) {
|
|
809
|
+
props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_CONDENSED_UPDATE, event.target.value === DENSITY_COMPACT);
|
|
810
|
+
},
|
|
811
|
+
onTextWrappingChange: function onTextWrappingChange(event) {
|
|
812
|
+
props.onSettingsChange(UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
|
|
813
|
+
},
|
|
814
|
+
managerTheme: props.managerTheme
|
|
815
|
+
})), openedPanelId === COLUMN_MANAGER && jsxRuntime.jsx(ColumnSettingsManager$1, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
|
|
816
|
+
availableColumns: props.columnManager.hideableColumns,
|
|
817
|
+
selectedColumns: selectedColumns,
|
|
818
|
+
onClose: handleSettingsPanelChange,
|
|
819
|
+
onUpdateColumns: function onUpdateColumns(nextVisibleColumns) {
|
|
820
|
+
var keysOfVisibleColumns = _mapInstanceProperty__default["default"](nextVisibleColumns).call(nextVisibleColumns, function (visibleColumn) {
|
|
821
|
+
return visibleColumn.key;
|
|
822
|
+
});
|
|
823
|
+
|
|
824
|
+
props.onSettingsChange(UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
|
|
825
|
+
},
|
|
826
|
+
managerTheme: props.managerTheme
|
|
827
|
+
}))]
|
|
828
|
+
});
|
|
755
829
|
};
|
|
756
830
|
|
|
757
831
|
DataTableSettings.displayName = 'DataTableSettings';
|
|
758
832
|
DataTableSettings.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
759
|
-
topBar: PropTypes__default[
|
|
760
|
-
onSettingsChange: PropTypes__default[
|
|
761
|
-
displaySettings: PropTypes__default[
|
|
762
|
-
disableDisplaySettings: PropTypes__default[
|
|
763
|
-
isCondensed: PropTypes__default[
|
|
764
|
-
isWrappingText: PropTypes__default[
|
|
765
|
-
primaryButton: PropTypes__default[
|
|
766
|
-
secondaryButton: PropTypes__default[
|
|
833
|
+
topBar: PropTypes__default["default"].node,
|
|
834
|
+
onSettingsChange: PropTypes__default["default"].func,
|
|
835
|
+
displaySettings: PropTypes__default["default"].shape({
|
|
836
|
+
disableDisplaySettings: PropTypes__default["default"].bool,
|
|
837
|
+
isCondensed: PropTypes__default["default"].bool,
|
|
838
|
+
isWrappingText: PropTypes__default["default"].bool,
|
|
839
|
+
primaryButton: PropTypes__default["default"].element,
|
|
840
|
+
secondaryButton: PropTypes__default["default"].element
|
|
767
841
|
}),
|
|
768
|
-
columnManager: PropTypes__default[
|
|
769
|
-
areHiddenColumnsSearchable: PropTypes__default[
|
|
770
|
-
disableColumnManager: PropTypes__default[
|
|
771
|
-
visibleColumnKeys: PropTypes__default[
|
|
772
|
-
hideableColumns: PropTypes__default[
|
|
773
|
-
key: PropTypes__default[
|
|
774
|
-
label: PropTypes__default[
|
|
775
|
-
}))
|
|
776
|
-
|
|
777
|
-
|
|
842
|
+
columnManager: PropTypes__default["default"].shape({
|
|
843
|
+
areHiddenColumnsSearchable: PropTypes__default["default"].bool,
|
|
844
|
+
disableColumnManager: PropTypes__default["default"].bool,
|
|
845
|
+
visibleColumnKeys: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string.isRequired),
|
|
846
|
+
hideableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
847
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
848
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
849
|
+
})),
|
|
850
|
+
searchHiddenColumns: PropTypes__default["default"].func,
|
|
851
|
+
searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
|
|
852
|
+
primaryButton: PropTypes__default["default"].element,
|
|
853
|
+
secondaryButton: PropTypes__default["default"].element
|
|
854
|
+
}),
|
|
855
|
+
managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
|
|
778
856
|
} : {};
|
|
779
857
|
var DataTableSettings$1 = DataTableSettings;
|
|
780
858
|
|
|
781
|
-
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default[
|
|
859
|
+
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (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; }
|
|
782
860
|
|
|
783
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty__default[
|
|
861
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context3; _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; }
|
|
784
862
|
|
|
785
863
|
var DataTableManager = function DataTableManager(props) {
|
|
786
864
|
var areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
787
865
|
var isWrappingText = areDisplaySettingsEnabled && props.displaySettings.isWrappingText;
|
|
788
|
-
var columns =
|
|
866
|
+
var columns = react.useMemo(function () {
|
|
789
867
|
var _context;
|
|
790
868
|
|
|
791
|
-
return _mapInstanceProperty__default[
|
|
869
|
+
return _mapInstanceProperty__default["default"](_context = props.columns).call(_context, function (column) {
|
|
792
870
|
return _objectSpread(_objectSpread({}, column), {}, {
|
|
793
871
|
isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
|
|
794
872
|
});
|
|
795
873
|
});
|
|
796
874
|
}, [areDisplaySettingsEnabled, props.columns, isWrappingText]);
|
|
797
|
-
return
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
875
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
876
|
+
children: [jsxRuntime.jsx(DataTableSettings$1, {
|
|
877
|
+
topBar: props.topBar,
|
|
878
|
+
onSettingsChange: props.onSettingsChange,
|
|
879
|
+
columnManager: props.columnManager,
|
|
880
|
+
displaySettings: props.displaySettings,
|
|
881
|
+
managerTheme: props.managerTheme
|
|
882
|
+
}), /*#__PURE__*/react.cloneElement(props.children, {
|
|
883
|
+
columns: columns,
|
|
884
|
+
isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
|
|
885
|
+
})]
|
|
886
|
+
});
|
|
807
887
|
};
|
|
808
888
|
|
|
809
889
|
DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
@@ -814,7 +894,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
814
894
|
* The list of columns to be rendered.
|
|
815
895
|
* Each column can be customized (see properties below).
|
|
816
896
|
*/
|
|
817
|
-
columns: PropTypes__default[
|
|
897
|
+
columns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
818
898
|
/**
|
|
819
899
|
* The unique key of the column that is used to identify your data type.
|
|
820
900
|
* You can use this value to determine which value from a row item should be rendered.
|
|
@@ -825,12 +905,12 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
825
905
|
* an explicit mapping of the value by implementing either the `itemRendered` function or
|
|
826
906
|
* the column-specific `renderItem` function.
|
|
827
907
|
*/
|
|
828
|
-
key: PropTypes__default[
|
|
908
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
829
909
|
|
|
830
910
|
/**
|
|
831
911
|
* The label of the column that will be shown on the column header.
|
|
832
912
|
*/
|
|
833
|
-
label: PropTypes__default[
|
|
913
|
+
label: PropTypes__default["default"].node.isRequired,
|
|
834
914
|
|
|
835
915
|
/**
|
|
836
916
|
* Sets a width for this column. Accepts the same values as the ones specified for
|
|
@@ -842,19 +922,19 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
842
922
|
*
|
|
843
923
|
* @@defaultValue@@: auto
|
|
844
924
|
*/
|
|
845
|
-
width: PropTypes__default[
|
|
925
|
+
width: PropTypes__default["default"].string,
|
|
846
926
|
|
|
847
927
|
/**
|
|
848
928
|
* Use this to override the table's own `horizontalCellAlignment` prop for this specific column.
|
|
849
929
|
*/
|
|
850
|
-
align: PropTypes__default[
|
|
930
|
+
align: PropTypes__default["default"].oneOf(['left', 'center', 'right']),
|
|
851
931
|
|
|
852
932
|
/**
|
|
853
933
|
* A callback function, called when the header cell is clicked.
|
|
854
934
|
* <br>
|
|
855
935
|
* Signature: `(event) => void`
|
|
856
936
|
*/
|
|
857
|
-
onClick: PropTypes__default[
|
|
937
|
+
onClick: PropTypes__default["default"].func,
|
|
858
938
|
|
|
859
939
|
/**
|
|
860
940
|
* A callback function to render the content of cells under this column, overriding
|
|
@@ -862,7 +942,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
862
942
|
* <br>
|
|
863
943
|
* Signature: `(row: object, isRowCollapsed: boolean) => React.Node`
|
|
864
944
|
*/
|
|
865
|
-
renderItem: PropTypes__default[
|
|
945
|
+
renderItem: PropTypes__default["default"].func,
|
|
866
946
|
|
|
867
947
|
/**
|
|
868
948
|
* Use this prop to place an `Icon` or `IconButton` on the left of the column label.
|
|
@@ -870,7 +950,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
870
950
|
* in order to properly position and align the elements.
|
|
871
951
|
* This is particularly useful for medium-sized icons which require more vertical space than the typography.
|
|
872
952
|
*/
|
|
873
|
-
headerIcon: PropTypes__default[
|
|
953
|
+
headerIcon: PropTypes__default["default"].node,
|
|
874
954
|
|
|
875
955
|
/**
|
|
876
956
|
* Set this to `true` to allow text content of this cell to be truncated with an ellipsis,
|
|
@@ -885,7 +965,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
885
965
|
*
|
|
886
966
|
* @@defaultValue@@: false
|
|
887
967
|
*/
|
|
888
|
-
isTruncated: PropTypes__default[
|
|
968
|
+
isTruncated: PropTypes__default["default"].bool,
|
|
889
969
|
|
|
890
970
|
/**
|
|
891
971
|
* Set this to `true` to show a sorting button, which calls `onSortChange` upon being clicked.
|
|
@@ -894,7 +974,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
894
974
|
*
|
|
895
975
|
* @@defaultValue@@: false
|
|
896
976
|
*/
|
|
897
|
-
isSortable: PropTypes__default[
|
|
977
|
+
isSortable: PropTypes__default["default"].bool,
|
|
898
978
|
|
|
899
979
|
/**
|
|
900
980
|
* Set this to `true` to prevent this column from being manually resized by dragging
|
|
@@ -902,7 +982,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
902
982
|
*
|
|
903
983
|
* @@defaultValue@@: false
|
|
904
984
|
*/
|
|
905
|
-
disableResizing: PropTypes__default[
|
|
985
|
+
disableResizing: PropTypes__default["default"].bool,
|
|
906
986
|
|
|
907
987
|
/**
|
|
908
988
|
* Set this to `true` to prevent click event propagation for this cell.
|
|
@@ -911,7 +991,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
911
991
|
*
|
|
912
992
|
* @@defaultValue@@: false
|
|
913
993
|
*/
|
|
914
|
-
shouldIgnoreRowClick: PropTypes__default[
|
|
994
|
+
shouldIgnoreRowClick: PropTypes__default["default"].bool
|
|
915
995
|
})).isRequired,
|
|
916
996
|
|
|
917
997
|
/**
|
|
@@ -919,18 +999,18 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
919
999
|
* <br>
|
|
920
1000
|
* Note that the child component will implicitly receive the props `columns` and `isCondensed` from the `<DataTableManager>`.
|
|
921
1001
|
*/
|
|
922
|
-
children: PropTypes__default[
|
|
1002
|
+
children: PropTypes__default["default"].node.isRequired,
|
|
923
1003
|
|
|
924
1004
|
/**
|
|
925
1005
|
* The managed display settings of the table.
|
|
926
1006
|
*/
|
|
927
|
-
displaySettings: PropTypes__default[
|
|
1007
|
+
displaySettings: PropTypes__default["default"].shape({
|
|
928
1008
|
/**
|
|
929
1009
|
* Set this flag to `false` to show the display settings panel option.
|
|
930
1010
|
*
|
|
931
1011
|
* @@defaultValue@@: true
|
|
932
1012
|
*/
|
|
933
|
-
disableDisplaySettings: PropTypes__default[
|
|
1013
|
+
disableDisplaySettings: PropTypes__default["default"].bool,
|
|
934
1014
|
|
|
935
1015
|
/**
|
|
936
1016
|
* Set this to `true` to reduce the paddings of all cells, allowing the table to display
|
|
@@ -938,7 +1018,7 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
938
1018
|
*
|
|
939
1019
|
* @@defaultValue@@: false
|
|
940
1020
|
*/
|
|
941
|
-
isCondensed: PropTypes__default[
|
|
1021
|
+
isCondensed: PropTypes__default["default"].bool,
|
|
942
1022
|
|
|
943
1023
|
/**
|
|
944
1024
|
* Set this to `true` to allow text in a cell to wrap.
|
|
@@ -947,69 +1027,69 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
947
1027
|
*
|
|
948
1028
|
* @@defaultValue@@: false
|
|
949
1029
|
*/
|
|
950
|
-
isWrappingText: PropTypes__default[
|
|
1030
|
+
isWrappingText: PropTypes__default["default"].bool,
|
|
951
1031
|
|
|
952
1032
|
/**
|
|
953
1033
|
* A React element to be rendered as the primary button, useful when the display settings work as a form.
|
|
954
1034
|
*/
|
|
955
|
-
primaryButton: PropTypes__default[
|
|
1035
|
+
primaryButton: PropTypes__default["default"].element,
|
|
956
1036
|
|
|
957
1037
|
/**
|
|
958
1038
|
* A React element to be rendered as the secondary button, useful when the display settings work as a form.
|
|
959
1039
|
*/
|
|
960
|
-
secondaryButton: PropTypes__default[
|
|
1040
|
+
secondaryButton: PropTypes__default["default"].element
|
|
961
1041
|
}),
|
|
962
1042
|
|
|
963
1043
|
/**
|
|
964
1044
|
* The managed column settings of the table.
|
|
965
1045
|
*/
|
|
966
|
-
columnManager: PropTypes__default[
|
|
1046
|
+
columnManager: PropTypes__default["default"].shape({
|
|
967
1047
|
/**
|
|
968
1048
|
* Set this to `false` to show the column settings panel option.
|
|
969
1049
|
*
|
|
970
1050
|
* @@defaultValue@@: true
|
|
971
1051
|
*/
|
|
972
|
-
disableColumnManager: PropTypes__default[
|
|
1052
|
+
disableColumnManager: PropTypes__default["default"].bool,
|
|
973
1053
|
|
|
974
1054
|
/**
|
|
975
1055
|
* The keys of the visible columns.
|
|
976
1056
|
*/
|
|
977
|
-
visibleColumnKeys: PropTypes__default[
|
|
1057
|
+
visibleColumnKeys: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string.isRequired),
|
|
978
1058
|
|
|
979
1059
|
/**
|
|
980
1060
|
* The keys of the visible columns.
|
|
981
1061
|
*/
|
|
982
|
-
hideableColumns: PropTypes__default[
|
|
983
|
-
key: PropTypes__default[
|
|
984
|
-
label: PropTypes__default[
|
|
1062
|
+
hideableColumns: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1063
|
+
key: PropTypes__default["default"].string.isRequired,
|
|
1064
|
+
label: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].node]).isRequired
|
|
985
1065
|
})),
|
|
986
1066
|
|
|
987
1067
|
/**
|
|
988
1068
|
* Set this to `true` to show a search input for the hidden columns panel.
|
|
989
1069
|
*/
|
|
990
|
-
areHiddenColumnsSearchable: PropTypes__default[
|
|
1070
|
+
areHiddenColumnsSearchable: PropTypes__default["default"].bool,
|
|
991
1071
|
|
|
992
1072
|
/**
|
|
993
1073
|
* A callback function, called when the search input for the hidden columns panel changes.
|
|
994
1074
|
* <br>
|
|
995
1075
|
* Signature: `(event) => void`
|
|
996
1076
|
*/
|
|
997
|
-
searchHiddenColumns: PropTypes__default[
|
|
1077
|
+
searchHiddenColumns: PropTypes__default["default"].func,
|
|
998
1078
|
|
|
999
1079
|
/**
|
|
1000
1080
|
* Placeholder value of the search input for the hidden columns panel.
|
|
1001
1081
|
*/
|
|
1002
|
-
searchHiddenColumnsPlaceholder: PropTypes__default[
|
|
1082
|
+
searchHiddenColumnsPlaceholder: PropTypes__default["default"].string,
|
|
1003
1083
|
|
|
1004
1084
|
/**
|
|
1005
1085
|
* A React element to be rendered as the primary button, useful when the column settings work as a form.
|
|
1006
1086
|
*/
|
|
1007
|
-
primaryButton: PropTypes__default[
|
|
1087
|
+
primaryButton: PropTypes__default["default"].element,
|
|
1008
1088
|
|
|
1009
1089
|
/**
|
|
1010
1090
|
* A React element to be rendered as the secondary button, useful when the column settings work as a form.
|
|
1011
1091
|
*/
|
|
1012
|
-
secondaryButton: PropTypes__default[
|
|
1092
|
+
secondaryButton: PropTypes__default["default"].element
|
|
1013
1093
|
}),
|
|
1014
1094
|
|
|
1015
1095
|
/**
|
|
@@ -1017,36 +1097,32 @@ DataTableManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
1017
1097
|
* <br>
|
|
1018
1098
|
* Signature: `(action: string, nextValue: object) => void`
|
|
1019
1099
|
*/
|
|
1020
|
-
onSettingsChange: PropTypes__default[
|
|
1100
|
+
onSettingsChange: PropTypes__default["default"].func,
|
|
1021
1101
|
|
|
1022
1102
|
/**
|
|
1023
1103
|
* A React node for rendering additional information within the table manager.
|
|
1024
1104
|
*/
|
|
1025
|
-
topBar: PropTypes__default[
|
|
1105
|
+
topBar: PropTypes__default["default"].node,
|
|
1026
1106
|
|
|
1027
1107
|
/**
|
|
1028
1108
|
* Sets the background theme of the Card that contains the settings
|
|
1029
1109
|
*/
|
|
1030
|
-
managerTheme: PropTypes__default[
|
|
1110
|
+
managerTheme: PropTypes__default["default"].oneOf(['light', 'dark'])
|
|
1031
1111
|
} : {};
|
|
1032
1112
|
DataTableManager.displayName = 'DataTableManager';
|
|
1033
1113
|
var DataTableManager$1 = DataTableManager;
|
|
1034
1114
|
|
|
1035
|
-
// NOTE: This string will be replaced
|
|
1036
|
-
var version =
|
|
1115
|
+
// NOTE: This string will be replaced on build time with the package version.
|
|
1116
|
+
var version = "12.2.6";
|
|
1037
1117
|
|
|
1038
1118
|
Object.defineProperty(exports, 'useRowSelection', {
|
|
1039
1119
|
enumerable: true,
|
|
1040
|
-
get: function () {
|
|
1041
|
-
return hooks.useRowSelection;
|
|
1042
|
-
}
|
|
1120
|
+
get: function () { return hooks.useRowSelection; }
|
|
1043
1121
|
});
|
|
1044
1122
|
Object.defineProperty(exports, 'useSorting', {
|
|
1045
1123
|
enumerable: true,
|
|
1046
|
-
get: function () {
|
|
1047
|
-
return hooks.useSorting;
|
|
1048
|
-
}
|
|
1124
|
+
get: function () { return hooks.useSorting; }
|
|
1049
1125
|
});
|
|
1050
1126
|
exports.UPDATE_ACTIONS = UPDATE_ACTIONS;
|
|
1051
|
-
exports[
|
|
1127
|
+
exports["default"] = DataTableManager$1;
|
|
1052
1128
|
exports.version = version;
|