@commercetools-uikit/data-table-manager 19.9.0 → 19.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +50 -35
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.d.ts +2 -0
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.dev.js +43 -0
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.js +7 -0
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.cjs.prod.js +43 -0
- package/column-settings-manager/dist/commercetools-uikit-data-table-manager-column-settings-manager.esm.js +35 -0
- package/column-settings-manager/package.json +4 -0
- package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.dev.js +6 -4
- package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.cjs.prod.js +6 -4
- package/data-table-manager-provider/dist/commercetools-uikit-data-table-manager-data-table-manager-provider.esm.js +6 -4
- package/dist/column-settings-manager-1430ee4f.esm.js +463 -0
- package/dist/column-settings-manager-92b54563.cjs.dev.js +494 -0
- package/dist/column-settings-manager-b08669e8.cjs.prod.js +407 -0
- package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +142 -464
- package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +137 -383
- package/dist/commercetools-uikit-data-table-manager.esm.js +143 -454
- package/dist/{data-table-manager-provider-3f60b85b.esm.js → data-table-manager-provider-32eb58dd.esm.js} +41 -9
- package/dist/{data-table-manager-provider-6c690fc1.cjs.dev.js → data-table-manager-provider-c64c81aa.cjs.prod.js} +43 -10
- package/dist/{data-table-manager-provider-ddf7fb63.cjs.prod.js → data-table-manager-provider-fc238633.cjs.dev.js} +43 -10
- package/dist/declarations/src/column-settings-manager/column-settings-manager.d.ts +26 -0
- package/dist/declarations/src/column-settings-manager/export-types.d.ts +3 -0
- package/dist/declarations/src/column-settings-manager/index.d.ts +2 -0
- package/dist/declarations/src/constants.d.ts +2 -0
- package/dist/declarations/src/data-table-manager-provider/data-table-manager-provider.d.ts +11 -2
- package/dist/declarations/src/data-table-manager-provider/types.d.ts +62 -0
- package/dist/declarations/src/export-types.d.ts +2 -0
- package/dist/declarations/src/index.d.ts +1 -0
- package/dist/declarations/src/settings-container/index.d.ts +2 -0
- package/dist/declarations/src/settings-container/settings-container.d.ts +23 -0
- package/dist/declarations/src/types.d.ts +203 -2
- package/package.json +29 -25
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
2
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
3
|
+
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
1
4
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
2
5
|
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
3
6
|
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
@@ -6,18 +9,16 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
|
|
|
6
9
|
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
7
10
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
8
11
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
9
|
-
import
|
|
10
|
-
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
11
|
-
import { useState, useMemo, useCallback, cloneElement } from 'react';
|
|
12
|
+
import { useState, useMemo, cloneElement } from 'react';
|
|
12
13
|
import Spacings from '@commercetools-uikit/spacings';
|
|
13
14
|
import { useDataTableManagerContext } from '@commercetools-uikit/data-table-manager/data-table-manager-provider';
|
|
14
15
|
import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
|
|
15
|
-
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
16
16
|
import _styled from '@emotion/styled/base';
|
|
17
|
+
import _Object$entries from '@babel/runtime-corejs3/core-js-stable/object/entries';
|
|
17
18
|
import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
18
19
|
import { warning } from '@commercetools-uikit/utils';
|
|
19
|
-
import {
|
|
20
|
-
import {
|
|
20
|
+
import { defineMessages, useIntl } from 'react-intl';
|
|
21
|
+
import { ColumnsIcon } from '@commercetools-uikit/icons';
|
|
21
22
|
import DropdownMenu from '@commercetools-uikit/dropdown-menu';
|
|
22
23
|
import IconButton from '@commercetools-uikit/icon-button';
|
|
23
24
|
import Tooltip from '@commercetools-uikit/tooltip';
|
|
@@ -27,119 +28,35 @@ import Grid from '@commercetools-uikit/grid';
|
|
|
27
28
|
import RadioInput from '@commercetools-uikit/radio-input';
|
|
28
29
|
import AccessibleHidden from '@commercetools-uikit/accessible-hidden';
|
|
29
30
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
30
|
-
import
|
|
31
|
-
|
|
32
|
-
import Card from '@commercetools-uikit/card';
|
|
33
|
-
import Text from '@commercetools-uikit/text';
|
|
34
|
-
import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
|
|
35
|
-
import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
|
|
36
|
-
import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
37
|
-
import { Draggable, Droppable, DragDropContext } from 'react-beautiful-dnd';
|
|
38
|
-
import debounce from 'debounce-promise';
|
|
39
|
-
import differenceWith from 'lodash/differenceWith';
|
|
40
|
-
import AsyncSelectInput from '@commercetools-uikit/async-select-input';
|
|
41
|
-
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
42
|
-
import Tag from '@commercetools-uikit/tag';
|
|
31
|
+
import { S as SettingsContainer, C as ColumnSettingsManager } from './column-settings-manager-1430ee4f.esm.js';
|
|
32
|
+
export { C as ColumnSettingsManager } from './column-settings-manager-1430ee4f.esm.js';
|
|
43
33
|
export { useRowSelection, useSorting } from '@commercetools-uikit/hooks';
|
|
44
|
-
export { D as DataTableManagerProvider, u as useDataTableManagerContext } from './data-table-manager-provider-
|
|
34
|
+
export { D as DataTableManagerProvider, u as useDataTableManagerContext } from './data-table-manager-provider-32eb58dd.esm.js';
|
|
35
|
+
import '@babel/runtime-corejs3/core-js-stable/promise';
|
|
36
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/slice';
|
|
37
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
38
|
+
import 'react-beautiful-dnd';
|
|
39
|
+
import 'debounce-promise';
|
|
40
|
+
import 'lodash/differenceWith';
|
|
41
|
+
import '@commercetools-uikit/async-select-input';
|
|
42
|
+
import '@commercetools-uikit/accessible-button';
|
|
43
|
+
import '@commercetools-uikit/collapsible-motion';
|
|
44
|
+
import '@commercetools-uikit/card';
|
|
45
|
+
import '@commercetools-uikit/text';
|
|
46
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
47
|
+
import '@commercetools-uikit/tag';
|
|
45
48
|
|
|
46
49
|
const UPDATE_ACTIONS = {
|
|
47
50
|
COLUMNS_UPDATE: 'columnsUpdate',
|
|
51
|
+
CUSTOM_SETTINGS_UPDATE: 'customSettingsUpdate',
|
|
52
|
+
CUSTOM_COLUMNS_UPDATE: 'customColumnsUpdate',
|
|
48
53
|
IS_TABLE_CONDENSED_UPDATE: 'isTableCondensedUpdate',
|
|
49
54
|
IS_TABLE_WRAPPING_TEXT_UPDATE: 'isTableWrappingTextUpdate'
|
|
50
55
|
};
|
|
51
56
|
const COLUMN_MANAGER = 'columnManager';
|
|
52
57
|
const DISPLAY_SETTINGS = 'displaySettings';
|
|
53
58
|
|
|
54
|
-
|
|
55
|
-
const HeaderContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
56
|
-
target: "e6ezr101"
|
|
57
|
-
} : {
|
|
58
|
-
target: "e6ezr101",
|
|
59
|
-
label: "HeaderContainer"
|
|
60
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
61
|
-
name: "1bhm8h2",
|
|
62
|
-
styles: "display:flex;flex:1;justify-content:space-between"
|
|
63
|
-
} : {
|
|
64
|
-
name: "1bhm8h2",
|
|
65
|
-
styles: "display:flex;flex:1;justify-content:space-between",
|
|
66
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJrQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUU2V0dGluZ3NDb250YWluZXJQcm9wcyA9IHtcbiAgdGl0bGU6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIGNsb3NlQnV0dG9uTGFiZWw6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIG9uQ2xvc2U6IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIHByaW1hcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIHNlY29uZGFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgY29udGFpbmVyVGhlbWU/OiAnbGlnaHQnIHwgJ2RhcmsnO1xufTtcblxuY29uc3QgSGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcblxuY29uc3QgQ2FyZENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuYDtcblxuY29uc3QgU2V0dGluZ3NDb250YWluZXIgPSAocHJvcHM6IFRTZXR0aW5nc0NvbnRhaW5lclByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cInJhaXNlZFwiIGluc2V0U2NhbGU9XCJub25lXCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgyXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */",
|
|
67
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
68
|
-
});
|
|
69
|
-
const CardContentWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
70
|
-
target: "e6ezr100"
|
|
71
|
-
} : {
|
|
72
|
-
target: "e6ezr100",
|
|
73
|
-
label: "CardContentWrapper"
|
|
74
|
-
})("padding:", designTokens.spacing40, " ", designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNldHRpbmdzLWNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNxQyIsImZpbGUiOiJzZXR0aW5ncy1jb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50LCBNb3VzZUV2ZW50LCBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIHR5cGUgTWVzc2FnZURlc2NyaXB0b3IgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBBY2Nlc3NpYmxlQnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2FjY2Vzc2libGUtYnV0dG9uJztcbmltcG9ydCBDb2xsYXBzaWJsZU1vdGlvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9jb2xsYXBzaWJsZS1tb3Rpb24nO1xuaW1wb3J0IENhcmQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY2FyZCc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBDbG9zZUljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxudHlwZSBUU2V0dGluZ3NDb250YWluZXJQcm9wcyA9IHtcbiAgdGl0bGU6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIGNsb3NlQnV0dG9uTGFiZWw6IE1lc3NhZ2VEZXNjcmlwdG9yICYge1xuICAgIHZhbHVlcz86IFJlY29yZDxzdHJpbmcsIFJlYWN0LlJlYWN0Tm9kZT47XG4gIH07XG4gIG9uQ2xvc2U6IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIHByaW1hcnlCdXR0b24/OiBSZWFjdEVsZW1lbnQ7XG4gIHNlY29uZGFyeUJ1dHRvbj86IFJlYWN0RWxlbWVudDtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgY29udGFpbmVyVGhlbWU/OiAnbGlnaHQnIHwgJ2RhcmsnO1xufTtcblxuY29uc3QgSGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcblxuY29uc3QgQ2FyZENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuYDtcblxuY29uc3QgU2V0dGluZ3NDb250YWluZXIgPSAocHJvcHM6IFRTZXR0aW5nc0NvbnRhaW5lclByb3BzKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb24gaXNEZWZhdWx0Q2xvc2VkPXtmYWxzZX0+XG4gICAgICB7KHsgcmVnaXN0ZXJDb250ZW50Tm9kZSwgY29udGFpbmVyU3R5bGVzIH0pID0+IChcbiAgICAgICAgPENhcmQgdHlwZT1cInJhaXNlZFwiIGluc2V0U2NhbGU9XCJub25lXCIgdGhlbWU9e3Byb3BzLmNvbnRhaW5lclRoZW1lfT5cbiAgICAgICAgICA8Q2FyZENvbnRlbnRXcmFwcGVyPlxuICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgICAgPEhlYWRlckNvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICA8VGV4dC5IZWFkbGluZSBhcz1cImgyXCIgaW50bE1lc3NhZ2U9e3Byb3BzLnRpdGxlfSAvPlxuICAgICAgICAgICAgICAgIDxBY2Nlc3NpYmxlQnV0dG9uXG4gICAgICAgICAgICAgICAgICBvbkNsaWNrPXtwcm9wcy5vbkNsb3NlfVxuICAgICAgICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShwcm9wcy5jbG9zZUJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICA8Q2xvc2VJY29uIHNpemU9XCJtZWRpdW1cIiAvPlxuICAgICAgICAgICAgICAgIDwvQWNjZXNzaWJsZUJ1dHRvbj5cbiAgICAgICAgICAgICAgPC9IZWFkZXJDb250YWluZXI+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5zZXQgc2NhbGU9XCJzXCI+XG4gICAgICAgICAgICAgICAgICA8ZGl2IHN0eWxlPXtjb250YWluZXJTdHlsZXN9PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX0+e3Byb3BzLmNoaWxkcmVufTwvZGl2PlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbnNldD5cbiAgICAgICAgICAgICAgICB7KHByb3BzLnNlY29uZGFyeUJ1dHRvbiB8fCBwcm9wcy5wcmltYXJ5QnV0dG9uKSAmJiAoXG4gICAgICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnNlY29uZGFyeUJ1dHRvbn1cbiAgICAgICAgICAgICAgICAgICAge3Byb3BzLnByaW1hcnlCdXR0b259XG4gICAgICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICA8L0NhcmRDb250ZW50V3JhcHBlcj5cbiAgICAgICAgPC9DYXJkPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApO1xufTtcblxuU2V0dGluZ3NDb250YWluZXIuZGlzcGxheU5hbWUgPSAnU2V0dGluZ3NDb250YWluZXInO1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBpY2s8VFNldHRpbmdzQ29udGFpbmVyUHJvcHMsICdjb250YWluZXJUaGVtZSc+ID0ge1xuICBjb250YWluZXJUaGVtZTogJ2RhcmsnLFxufTtcblNldHRpbmdzQ29udGFpbmVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgU2V0dGluZ3NDb250YWluZXI7XG4iXX0= */"));
|
|
75
|
-
const SettingsContainer = props => {
|
|
76
|
-
const intl = useIntl();
|
|
77
|
-
return jsx(CollapsibleMotion, {
|
|
78
|
-
isDefaultClosed: false,
|
|
79
|
-
children: _ref => {
|
|
80
|
-
let registerContentNode = _ref.registerContentNode,
|
|
81
|
-
containerStyles = _ref.containerStyles;
|
|
82
|
-
return jsx(Card, {
|
|
83
|
-
type: "raised",
|
|
84
|
-
insetScale: "none",
|
|
85
|
-
theme: props.containerTheme,
|
|
86
|
-
children: jsx(CardContentWrapper, {
|
|
87
|
-
children: jsxs(Spacings.Stack, {
|
|
88
|
-
scale: "xl",
|
|
89
|
-
children: [jsxs(HeaderContainer, {
|
|
90
|
-
children: [jsx(Text.Headline, {
|
|
91
|
-
as: "h2",
|
|
92
|
-
intlMessage: props.title
|
|
93
|
-
}), jsx(AccessibleButton, {
|
|
94
|
-
onClick: props.onClose,
|
|
95
|
-
label: intl.formatMessage(props.closeButtonLabel),
|
|
96
|
-
children: jsx(CloseIcon, {
|
|
97
|
-
size: "medium"
|
|
98
|
-
})
|
|
99
|
-
})]
|
|
100
|
-
}), jsxs(Spacings.Stack, {
|
|
101
|
-
scale: "l",
|
|
102
|
-
children: [jsx(Spacings.Inset, {
|
|
103
|
-
scale: "s",
|
|
104
|
-
children: jsx("div", {
|
|
105
|
-
style: containerStyles,
|
|
106
|
-
children: jsx("div", {
|
|
107
|
-
ref: registerContentNode,
|
|
108
|
-
children: props.children
|
|
109
|
-
})
|
|
110
|
-
})
|
|
111
|
-
}), (props.secondaryButton || props.primaryButton) && jsxs(Spacings.Inline, {
|
|
112
|
-
justifyContent: "flex-end",
|
|
113
|
-
children: [props.secondaryButton, props.primaryButton]
|
|
114
|
-
})]
|
|
115
|
-
})]
|
|
116
|
-
})
|
|
117
|
-
})
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
});
|
|
121
|
-
};
|
|
122
|
-
SettingsContainer.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
123
|
-
title: _pt.oneOfType([_pt.any, _pt.shape({
|
|
124
|
-
values: _pt.objectOf(_pt.node)
|
|
125
|
-
})]).isRequired,
|
|
126
|
-
closeButtonLabel: _pt.oneOfType([_pt.any, _pt.shape({
|
|
127
|
-
values: _pt.objectOf(_pt.node)
|
|
128
|
-
})]).isRequired,
|
|
129
|
-
onClose: _pt.func.isRequired,
|
|
130
|
-
primaryButton: _pt.element,
|
|
131
|
-
secondaryButton: _pt.element,
|
|
132
|
-
children: _pt.node.isRequired,
|
|
133
|
-
containerTheme: _pt.oneOf(['light', 'dark'])
|
|
134
|
-
} : {};
|
|
135
|
-
SettingsContainer.displayName = 'SettingsContainer';
|
|
136
|
-
const defaultProps$2 = {
|
|
137
|
-
containerTheme: 'dark'
|
|
138
|
-
};
|
|
139
|
-
SettingsContainer.defaultProps = defaultProps$2;
|
|
140
|
-
var SettingsContainer$1 = SettingsContainer;
|
|
141
|
-
|
|
142
|
-
var messages$3 = defineMessages({
|
|
59
|
+
var messages$2 = defineMessages({
|
|
143
60
|
title: {
|
|
144
61
|
id: 'UIKit.DataTableManager.DensityManager.title',
|
|
145
62
|
description: 'Title for the density manager component.',
|
|
@@ -191,9 +108,10 @@ const DensityManager = props => {
|
|
|
191
108
|
const intl = useIntl();
|
|
192
109
|
const textWrappingOption = props.isWrappingText ? SHOW_HIDE_ON_DEMAND : WRAPPED_TEXT_VISIBLE;
|
|
193
110
|
const densityDisplayOption = props.isCondensed ? DENSITY_COMPACT : DENSITY_COMFORTABLE;
|
|
194
|
-
return jsx(SettingsContainer
|
|
195
|
-
|
|
196
|
-
|
|
111
|
+
return jsx(SettingsContainer, {
|
|
112
|
+
customSettingsTitle: props.title,
|
|
113
|
+
title: messages$2.title,
|
|
114
|
+
closeButtonLabel: messages$2.closeButtonLabel,
|
|
197
115
|
onClose: props.onClose,
|
|
198
116
|
primaryButton: props.primaryButton,
|
|
199
117
|
secondaryButton: props.secondaryButton,
|
|
@@ -205,7 +123,7 @@ const DensityManager = props => {
|
|
|
205
123
|
children: jsxs(Spacings.Stack, {
|
|
206
124
|
scale: 'l',
|
|
207
125
|
children: [jsx(FieldLabel, {
|
|
208
|
-
title: intl.formatMessage(messages$
|
|
126
|
+
title: intl.formatMessage(messages$2.textWrappingSubtitle)
|
|
209
127
|
}), jsxs(AccessibleHidden, {
|
|
210
128
|
children: [jsx("label", {
|
|
211
129
|
htmlFor: "text-wrapping-0",
|
|
@@ -221,10 +139,10 @@ const DensityManager = props => {
|
|
|
221
139
|
onChange: props.onTextWrappingChange,
|
|
222
140
|
children: [jsx(RadioInput.Option, {
|
|
223
141
|
value: WRAPPED_TEXT_VISIBLE,
|
|
224
|
-
children: intl.formatMessage(messages$
|
|
142
|
+
children: intl.formatMessage(messages$2.textWrappingAllWrapVisibleOption)
|
|
225
143
|
}), jsx(RadioInput.Option, {
|
|
226
144
|
value: SHOW_HIDE_ON_DEMAND,
|
|
227
|
-
children: intl.formatMessage(messages$
|
|
145
|
+
children: intl.formatMessage(messages$2.textWrappingShowHideOnDemandOption)
|
|
228
146
|
})]
|
|
229
147
|
})]
|
|
230
148
|
})
|
|
@@ -232,7 +150,7 @@ const DensityManager = props => {
|
|
|
232
150
|
children: jsxs(Spacings.Stack, {
|
|
233
151
|
scale: 'l',
|
|
234
152
|
children: [jsx(FieldLabel, {
|
|
235
|
-
title: intl.formatMessage(messages$
|
|
153
|
+
title: intl.formatMessage(messages$2.densityDisplaySubtitle)
|
|
236
154
|
}), jsxs(AccessibleHidden, {
|
|
237
155
|
children: [jsx("label", {
|
|
238
156
|
htmlFor: "density-display-0",
|
|
@@ -248,10 +166,10 @@ const DensityManager = props => {
|
|
|
248
166
|
onChange: props.onDensityDisplayChange,
|
|
249
167
|
children: [jsx(RadioInput.Option, {
|
|
250
168
|
value: DENSITY_COMFORTABLE,
|
|
251
|
-
children: intl.formatMessage(messages$
|
|
169
|
+
children: intl.formatMessage(messages$2.densityDisplayComfortableOption)
|
|
252
170
|
}), jsx(RadioInput.Option, {
|
|
253
171
|
value: DENSITY_COMPACT,
|
|
254
|
-
children: intl.formatMessage(messages$
|
|
172
|
+
children: intl.formatMessage(messages$2.densityDisplayCompactOption)
|
|
255
173
|
})]
|
|
256
174
|
})]
|
|
257
175
|
})
|
|
@@ -260,6 +178,7 @@ const DensityManager = props => {
|
|
|
260
178
|
});
|
|
261
179
|
};
|
|
262
180
|
DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
181
|
+
title: _pt.string,
|
|
263
182
|
isCondensed: _pt.bool,
|
|
264
183
|
isWrappingText: _pt.bool,
|
|
265
184
|
primaryButton: _pt.element,
|
|
@@ -270,344 +189,40 @@ DensityManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
270
189
|
managerTheme: _pt.oneOf(['light', 'dark'])
|
|
271
190
|
} : {};
|
|
272
191
|
DensityManager.displayName = 'DensityManager';
|
|
273
|
-
const defaultProps
|
|
192
|
+
const defaultProps = {
|
|
274
193
|
isCondensed: true,
|
|
275
194
|
isWrappingText: false
|
|
276
195
|
};
|
|
277
|
-
DensityManager.defaultProps = defaultProps
|
|
196
|
+
DensityManager.defaultProps = defaultProps;
|
|
278
197
|
var DisplaySettingsManager = DensityManager;
|
|
279
198
|
|
|
280
|
-
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)."; }
|
|
281
|
-
const DraggingSmall = /*#__PURE__*/_styled("small", process.env.NODE_ENV === "production" ? {
|
|
282
|
-
target: "e1mp438g1"
|
|
283
|
-
} : {
|
|
284
|
-
target: "e1mp438g1",
|
|
285
|
-
label: "DraggingSmall"
|
|
286
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
287
|
-
name: "1fhyj3b",
|
|
288
|
-
styles: "&:hover{cursor:grab;}"
|
|
289
|
-
} : {
|
|
290
|
-
name: "1fhyj3b",
|
|
291
|
-
styles: "&:hover{cursor:grab;}",
|
|
292
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFa0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */",
|
|
293
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
294
|
-
});
|
|
295
|
-
const DraggingContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
296
|
-
target: "e1mp438g0"
|
|
297
|
-
} : {
|
|
298
|
-
target: "e1mp438g0",
|
|
299
|
-
label: "DraggingContainer"
|
|
300
|
-
})(DraggingSmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcuc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRb0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBEcmFnZ2luZ1NtYWxsID0gc3R5bGVkLnNtYWxsYFxuICAmOmhvdmVyIHtcbiAgICBjdXJzb3I6IGdyYWI7XG4gIH1cbmA7XG5cbmNvbnN0IERyYWdnaW5nQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgJHtEcmFnZ2luZ1NtYWxsfTtcbmA7XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdnaW5nQ29udGFpbmVyO1xuIl19 */"));
|
|
301
|
-
var DraggingContainer$1 = DraggingContainer;
|
|
302
|
-
|
|
303
|
-
function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
304
|
-
function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
305
|
-
const DraggableTagWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
306
|
-
target: "emzjy4n0"
|
|
307
|
-
} : {
|
|
308
|
-
target: "emzjy4n0",
|
|
309
|
-
label: "DraggableTagWrapper"
|
|
310
|
-
})("padding:", designTokens.spacing10, " 0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyYWdnYWJsZS10YWcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Cc0MiLCJmaWxlIjoiZHJhZ2dhYmxlLXRhZy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IERyYWdnYWJsZSB9IGZyb20gJ3JlYWN0LWJlYXV0aWZ1bC1kbmQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgVGFnIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RhZyc7XG5pbXBvcnQgRHJhZ2dpbmdDb250YWluZXIgZnJvbSAnLi9kcmFnZ2FibGUtdGFnLnN0eWxlcyc7XG5cbmV4cG9ydCB0eXBlIFRDb2x1bW5EYXRhID0ge1xuICBrZXk6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFREcmFnZ2FibGVUYWdQcm9wcyA9IHtcbiAgY29sdW1uOiBUQ29sdW1uRGF0YTtcbiAgaW5kZXg6IG51bWJlcjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIG9uUmVtb3ZlPzogKGluZGV4OiBudW1iZXIpID0+IHZvaWQ7XG59O1xuXG5jb25zdCBEcmFnZ2FibGVUYWdXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfSAwO1xuYDtcblxuY29uc3QgRHJhZ2dhYmxlVGFnID0gKHByb3BzOiBURHJhZ2dhYmxlVGFnUHJvcHMpID0+IHtcbiAgY29uc3QgaGFuZGxlUmVtb3ZlQ29sdW1uID0gKCkgPT4gcHJvcHMub25SZW1vdmU/Lihwcm9wcy5pbmRleCk7XG5cbiAgcmV0dXJuIChcbiAgICA8RHJhZ2dhYmxlXG4gICAgICBkcmFnZ2FibGVJZD17cHJvcHMuY29sdW1uLmtleX1cbiAgICAgIGluZGV4PXtwcm9wcy5pbmRleH1cbiAgICAgIGlzRHJhZ0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgID5cbiAgICAgIHsocHJvdmlkZWQpID0+IHtcbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8RHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgICAgIDxEcmFnZ2luZ0NvbnRhaW5lclxuICAgICAgICAgICAgICByZWY9e3Byb3ZpZGVkLmlubmVyUmVmfVxuICAgICAgICAgICAgICB7Li4ucHJvdmlkZWQuZHJhZ2dhYmxlUHJvcHN9XG4gICAgICAgICAgICAgIHsuLi5wcm92aWRlZC5kcmFnSGFuZGxlUHJvcHN9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUYWdcbiAgICAgICAgICAgICAgICBvblJlbW92ZT17cHJvcHMub25SZW1vdmUgPyBoYW5kbGVSZW1vdmVDb2x1bW4gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgICBpc0RyYWdnYWJsZVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3Byb3BzLmNvbHVtbi5sYWJlbH1cbiAgICAgICAgICAgICAgPC9UYWc+XG4gICAgICAgICAgICA8L0RyYWdnaW5nQ29udGFpbmVyPlxuICAgICAgICAgIDwvRHJhZ2dhYmxlVGFnV3JhcHBlcj5cbiAgICAgICAgKTtcbiAgICAgIH19XG4gICAgPC9EcmFnZ2FibGU+XG4gICk7XG59O1xuXG5EcmFnZ2FibGVUYWcuZGlzcGxheU5hbWUgPSAnRHJhZ2dhYmxlVGFnJztcblxuZXhwb3J0IGRlZmF1bHQgRHJhZ2dhYmxlVGFnO1xuIl19 */"));
|
|
311
|
-
const DraggableTag = props => {
|
|
312
|
-
const handleRemoveColumn = () => {
|
|
313
|
-
var _props$onRemove;
|
|
314
|
-
return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, props.index);
|
|
315
|
-
};
|
|
316
|
-
return jsx(Draggable, {
|
|
317
|
-
draggableId: props.column.key,
|
|
318
|
-
index: props.index,
|
|
319
|
-
isDragDisabled: props.isDisabled,
|
|
320
|
-
children: provided => {
|
|
321
|
-
return jsx(DraggableTagWrapper, {
|
|
322
|
-
children: jsx(DraggingContainer$1, _objectSpread$3(_objectSpread$3(_objectSpread$3({
|
|
323
|
-
ref: provided.innerRef
|
|
324
|
-
}, provided.draggableProps), provided.dragHandleProps), {}, {
|
|
325
|
-
children: jsx(Tag, {
|
|
326
|
-
onRemove: props.onRemove ? handleRemoveColumn : undefined,
|
|
327
|
-
isDisabled: props.isDisabled,
|
|
328
|
-
isDraggable: true,
|
|
329
|
-
children: props.column.label
|
|
330
|
-
})
|
|
331
|
-
}))
|
|
332
|
-
});
|
|
333
|
-
}
|
|
334
|
-
});
|
|
335
|
-
};
|
|
336
|
-
DraggableTag.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
337
|
-
column: _pt.shape({
|
|
338
|
-
key: _pt.string.isRequired,
|
|
339
|
-
label: _pt.node.isRequired
|
|
340
|
-
}).isRequired,
|
|
341
|
-
index: _pt.number.isRequired,
|
|
342
|
-
isDisabled: _pt.bool,
|
|
343
|
-
onRemove: _pt.func
|
|
344
|
-
} : {};
|
|
345
|
-
DraggableTag.displayName = 'DraggableTag';
|
|
346
|
-
var DraggableTag$1 = DraggableTag;
|
|
347
|
-
|
|
348
|
-
const TagContainerEditable = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
349
|
-
target: "e7rakq0"
|
|
350
|
-
} : {
|
|
351
|
-
target: "e7rakq0",
|
|
352
|
-
label: "TagContainerEditable"
|
|
353
|
-
})("background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";padding:", designTokens.spacing30, ";height:", designTokens.constraint7, ";overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhZy1jb250YWluZXItZWRpdGFibGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJ0YWctY29udGFpbmVyLWVkaXRhYmxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBUYWdDb250YWluZXJFZGl0YWJsZSA9IHN0eWxlZC5kaXZgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ3fTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBUYWdDb250YWluZXJFZGl0YWJsZTtcbiJdfQ== */"));
|
|
354
|
-
var TagContainerEditable$1 = TagContainerEditable;
|
|
355
|
-
|
|
356
|
-
var messages$2 = defineMessages({
|
|
357
|
-
loadMoreAttributesHint: {
|
|
358
|
-
id: 'UIKit.DataTableManager.ColumnManager.DroppablePanel.loadMoreAttributesHint',
|
|
359
|
-
description: 'Indicate that the user can use the search input to load more attributes',
|
|
360
|
-
defaultMessage: 'Load more attributes by using the search input above'
|
|
361
|
-
}
|
|
362
|
-
});
|
|
363
|
-
|
|
364
|
-
const DroppablePanel = props => {
|
|
365
|
-
return jsx(Droppable, {
|
|
366
|
-
droppableId: props.droppableId,
|
|
367
|
-
children: provided => {
|
|
368
|
-
var _context;
|
|
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, (column, index) => {
|
|
380
|
-
var _context2;
|
|
381
|
-
return jsx(DraggableTag$1, {
|
|
382
|
-
column: column,
|
|
383
|
-
index: index,
|
|
384
|
-
onRemove: props.onRemove ? () => {
|
|
385
|
-
var _context3, _context4;
|
|
386
|
-
return props.onRemove([..._sliceInstanceProperty(_context3 = props.columns).call(_context3, 0, index), ..._sliceInstanceProperty(_context4 = props.columns).call(_context4, index + 1)]);
|
|
387
|
-
} : undefined,
|
|
388
|
-
isDisabled: props.isDisabled
|
|
389
|
-
}, _concatInstanceProperty(_context2 = "".concat(column.key, "-")).call(_context2, index));
|
|
390
|
-
}), props.isSearchable && jsx(Spacings.Inset, {
|
|
391
|
-
scale: "xs",
|
|
392
|
-
children: jsx(Text.Detail, {
|
|
393
|
-
tone: "secondary",
|
|
394
|
-
intlMessage: messages$2.loadMoreAttributesHint
|
|
395
|
-
})
|
|
396
|
-
})]
|
|
397
|
-
}), provided.placeholder]
|
|
398
|
-
});
|
|
399
|
-
}
|
|
400
|
-
});
|
|
401
|
-
};
|
|
402
|
-
DroppablePanel.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
403
|
-
droppableId: _pt.string.isRequired,
|
|
404
|
-
noColumnsText: _pt.node.isRequired,
|
|
405
|
-
columns: _pt.arrayOf(_pt.shape({
|
|
406
|
-
key: _pt.string.isRequired,
|
|
407
|
-
label: _pt.node.isRequired
|
|
408
|
-
})).isRequired,
|
|
409
|
-
isSearchable: _pt.bool,
|
|
410
|
-
isDisabled: _pt.bool,
|
|
411
|
-
onRemove: _pt.func
|
|
412
|
-
} : {};
|
|
413
|
-
DroppablePanel.displayName = 'DroppablePanel';
|
|
414
|
-
var DroppablePanel$1 = DroppablePanel;
|
|
415
|
-
|
|
416
199
|
var messages$1 = defineMessages({
|
|
417
|
-
title: {
|
|
418
|
-
id: 'UIKit.DataTableManager.ColumnManager.title',
|
|
419
|
-
description: 'Title for the column manager component.',
|
|
420
|
-
defaultMessage: 'Column Manager'
|
|
421
|
-
},
|
|
422
|
-
visibleColumns: {
|
|
423
|
-
id: 'UIKit.DataTableManager.ColumnSelectorGroups.visible',
|
|
424
|
-
description: 'Message for the visible columns section.',
|
|
425
|
-
defaultMessage: 'Visible columns'
|
|
426
|
-
},
|
|
427
|
-
hiddenColumns: {
|
|
428
|
-
id: 'UIKit.DataTableManager.ColumnManager.hiddenColumns',
|
|
429
|
-
description: 'Message for the hidden columns section',
|
|
430
|
-
defaultMessage: 'Hidden columns'
|
|
431
|
-
},
|
|
432
|
-
noSelectedColumnsToShow: {
|
|
433
|
-
id: 'UIKit.DataTableManager.ColumnManager.noSelectedColumnsToShow',
|
|
434
|
-
description: 'Label when there are no selected columns to show',
|
|
435
|
-
defaultMessage: 'There are no selected columns to show.'
|
|
436
|
-
},
|
|
437
|
-
noHiddenColumnsToShow: {
|
|
438
|
-
id: 'UIKit.DataTableManager.ColumnManager.noHiddenColumnsToShow',
|
|
439
|
-
description: 'Label when there are no hidden columns to show',
|
|
440
|
-
defaultMessage: 'There are no hidden columns to show.'
|
|
441
|
-
},
|
|
442
200
|
closeButtonLabel: {
|
|
443
|
-
id: 'UIKit.DataTableManager.
|
|
444
|
-
description: 'Label for
|
|
201
|
+
id: 'UIKit.DataTableManager.CustomSettingsManager.closeButtonLabel',
|
|
202
|
+
description: 'Label for custom settings manager close button.',
|
|
445
203
|
defaultMessage: 'Close'
|
|
446
204
|
}
|
|
447
205
|
});
|
|
448
206
|
|
|
449
|
-
const
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
const DroppableContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
458
|
-
target: "en01od20"
|
|
459
|
-
} : {
|
|
460
|
-
target: "en01od20",
|
|
461
|
-
label: "DroppableContainer"
|
|
462
|
-
})("width:100%;position:relative;max-width:", designTokens.constraint10, ";cursor:", props => props.isDragging ? 'grabbing' : 'auto', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["column-settings-manager.tsx"],"names":[],"mappings":"AA+D+D","file":"column-settings-manager.tsx","sourcesContent":["import {\n  useMemo,\n  useCallback,\n  useState,\n  type ReactElement,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  type Dispatch,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { DragDropContext, type DropResult } from 'react-beautiful-dnd';\nimport debounce from 'debounce-promise';\nimport differenceWith from 'lodash/differenceWith';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport AsyncSelectInput from '@commercetools-uikit/async-select-input';\nimport FieldLabel from '@commercetools-uikit/field-label';\nimport Spacings from '@commercetools-uikit/spacings';\nimport {\n  EyeCrossedIcon,\n  EyeIcon,\n  SearchIcon,\n} from '@commercetools-uikit/icons';\nimport { warning } from '@commercetools-uikit/utils';\nimport DroppablePanel from '../droppable-panel';\nimport SettingsContainer from '../settings-container';\nimport messages from './messages';\nimport { HIDDEN_COLUMNS_PANEL, SELECTED_COLUMNS_PANEL } from './constants';\n\n// 'searchHiddenColums' is only required if 'areHiddenColumnsSearchable' is true\n// but that callback is used in AsyncSelectInput.loadOptions which is required\n// That property (loadOptions) is passed to react-select AsyncSelect where it's\n// declared as optional\nconst noSearch = () => Promise.resolve([]);\n// 'onChange' prop in AsyncSelectInput is required but not needed here\nconst voidChangeHandler = () => undefined;\n\nexport type TColumnData = {\n  key: string;\n  label: ReactNode;\n};\n\nexport type TColumnSettingsManagerProps = {\n  availableColumns: TColumnData[];\n  selectedColumns: TColumnData[];\n  onUpdateColumns: (updatedColums: TColumnData[]) => void;\n  areHiddenColumnsSearchable?: boolean;\n  searchHiddenColumns?: (searchTerm: string) => Promise<void> | void;\n  searchHiddenColumnsPlaceholder?: string;\n\n  onClose: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  primaryButton?: ReactElement;\n  secondaryButton?: ReactElement;\n  managerTheme?: 'light' | 'dark';\n};\n\ntype TDroppableContainerProps = {\n  isDragging: boolean;\n};\n\nconst DroppableContainer = styled.div<TDroppableContainerProps>`\n  width: 100%;\n  position: relative;\n  max-width: ${designTokens.constraint10};\n  cursor: ${(props) => (props.isDragging ? 'grabbing' : 'auto')};\n`;\n\nexport const handleColumnsUpdate = (\n  dragResult: DropResult,\n  onUpdateColumns: TColumnSettingsManagerProps['onUpdateColumns'],\n  selectedColumns: TColumnSettingsManagerProps['selectedColumns'],\n  availableColumns: TColumnSettingsManagerProps['availableColumns'],\n  setIsDragging: Dispatch<boolean>\n) => {\n  setIsDragging(false);\n  // Invalid drop destination, do nothing\n  if (!dragResult.destination) return;\n  if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {\n    if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;\n    onUpdateColumns([\n      ...selectedColumns.slice(0, dragResult.source.index),\n      ...selectedColumns.slice(dragResult.source.index + 1),\n    ]);\n  } else {\n    // the destination is the selected columns panel\n\n    // it's a swap when the source and the destination are the same\n    const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;\n\n    const items = isSwap\n      ? // remove the dragged item from its position if it is not coming from\n        // the hidden section (it is a swap)\n        [\n          ...selectedColumns.slice(0, dragResult.source.index),\n          ...selectedColumns.slice(dragResult.source.index + 1),\n        ]\n      : selectedColumns;\n\n    const columns = isSwap ? selectedColumns : availableColumns;\n    const draggedColumn = columns.find(\n      (col) => col.key === dragResult.draggableId\n    );\n\n    // push the column in the new position if draggedColumn is found\n    if (draggedColumn) {\n      onUpdateColumns([\n        ...items.slice(0, dragResult.destination.index),\n        draggedColumn,\n        ...items.slice(dragResult.destination.index),\n      ]);\n    }\n  }\n};\n\nconst DropdownIndicator = () => (\n  <Spacings.Inline alignItems=\"center\">\n    <SearchIcon size=\"medium\" color=\"primary\" />\n  </Spacings.Inline>\n);\nDropdownIndicator.displayName = 'DropdownIndicator';\n\nconst Nothing = () => null;\nconst selectInputComponents = {\n  Option: Nothing,\n  Menu: Nothing,\n  DropdownIndicator,\n};\n\nexport const ColumnSettingsManager = (props: TColumnSettingsManagerProps) => {\n  if (props.areHiddenColumnsSearchable) {\n    warning(\n      typeof props.searchHiddenColumns !== 'undefined',\n      'ui-kit/ColumnSettingsManager: \"searchHiddenColumns\" must be provided when \"areHiddenColumnsSearchable\" is true'\n    );\n  }\n\n  const intl = useIntl();\n  const [isDragging, setIsDragging] = useState(false);\n  const { searchHiddenColumns } = props;\n\n  const handleDragStart = () => {\n    setIsDragging(true);\n  };\n\n  const hiddenColumns = useMemo(\n    () =>\n      differenceWith(\n        props.availableColumns,\n        props.selectedColumns,\n        (a, b) => a.key === b.key\n      ),\n    [props.availableColumns, props.selectedColumns]\n  );\n\n  const handleDragEnd = useCallback<(dragResult: DropResult) => void>(\n    (dragResult) =>\n      handleColumnsUpdate(\n        dragResult,\n        props.onUpdateColumns,\n        props.selectedColumns,\n        props.availableColumns,\n        setIsDragging\n      ),\n    [props.onUpdateColumns, props.selectedColumns, props.availableColumns]\n  );\n\n  const debouncedSearchHiddenColumns = useMemo(\n    () => debounce(searchHiddenColumns ?? noSearch, 300),\n    [searchHiddenColumns]\n  );\n  const handleInputChange = useCallback<(inputValue: string) => void>(\n    (inputValue) => debouncedSearchHiddenColumns(inputValue),\n    [debouncedSearchHiddenColumns]\n  );\n\n  return (\n    <SettingsContainer\n      title={messages.title}\n      closeButtonLabel={messages.closeButtonLabel}\n      onClose={props.onClose}\n      primaryButton={props.primaryButton}\n      secondaryButton={props.secondaryButton}\n      containerTheme={props.managerTheme}\n    >\n      <DragDropContext onDragEnd={handleDragEnd} onDragStart={handleDragStart}>\n        <Spacings.Inline scale=\"l\">\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"hidden-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                <EyeCrossedIcon size=\"big\" />\n                <FieldLabel\n                  id=\"hidden-columns\"\n                  title={intl.formatMessage(messages.hiddenColumns)}\n                />\n              </Spacings.Inline>\n              {props.areHiddenColumnsSearchable && (\n                <AsyncSelectInput\n                  {...(props.searchHiddenColumnsPlaceholder\n                    ? {\n                        placeholder: props.searchHiddenColumnsPlaceholder,\n                      }\n                    : undefined)}\n                  onChange={voidChangeHandler}\n                  loadOptions={noSearch}\n                  onInputChange={handleInputChange}\n                  components={selectInputComponents}\n                />\n              )}\n              <DroppablePanel\n                droppableId={HIDDEN_COLUMNS_PANEL}\n                data-testid={HIDDEN_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noHiddenColumnsToShow\n                )}\n                columns={hiddenColumns}\n                isSearchable={props.areHiddenColumnsSearchable}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n          <DroppableContainer\n            isDragging={isDragging}\n            aria-labelledby=\"visible-columns\"\n          >\n            <Spacings.Stack scale=\"m\">\n              <Spacings.Inline scale=\"xs\" alignItems=\"center\">\n                <EyeIcon size=\"medium\" />\n                <FieldLabel\n                  id=\"visible-columns\"\n                  title={intl.formatMessage(messages.visibleColumns)}\n                />\n              </Spacings.Inline>\n              <DroppablePanel\n                droppableId={SELECTED_COLUMNS_PANEL}\n                data-testid={SELECTED_COLUMNS_PANEL}\n                noColumnsText={intl.formatMessage(\n                  messages.noSelectedColumnsToShow\n                )}\n                columns={props.selectedColumns}\n                onRemove={props.onUpdateColumns}\n              />\n            </Spacings.Stack>\n          </DroppableContainer>\n        </Spacings.Inline>\n      </DragDropContext>\n    </SettingsContainer>\n  );\n};\n\nColumnSettingsManager.displayName = 'ColumnSettingsManager';\n\nconst defaultProps: Pick<TColumnSettingsManagerProps, 'availableColumns'> = {\n  availableColumns: [],\n};\nColumnSettingsManager.defaultProps = defaultProps;\n\nexport default ColumnSettingsManager;\n"]} */"));
|
|
463
|
-
const handleColumnsUpdate = (dragResult, onUpdateColumns, selectedColumns, availableColumns, setIsDragging) => {
|
|
464
|
-
setIsDragging(false);
|
|
465
|
-
// Invalid drop destination, do nothing
|
|
466
|
-
if (!dragResult.destination) return;
|
|
467
|
-
if (dragResult.destination.droppableId === HIDDEN_COLUMNS_PANEL) {
|
|
468
|
-
if (dragResult.source.droppableId === HIDDEN_COLUMNS_PANEL) return;
|
|
469
|
-
onUpdateColumns([..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)]);
|
|
470
|
-
} else {
|
|
471
|
-
// the destination is the selected columns panel
|
|
472
|
-
|
|
473
|
-
// it's a swap when the source and the destination are the same
|
|
474
|
-
const isSwap = dragResult.source.droppableId === SELECTED_COLUMNS_PANEL;
|
|
475
|
-
const items = isSwap ?
|
|
476
|
-
// remove the dragged item from its position if it is not coming from
|
|
477
|
-
// the hidden section (it is a swap)
|
|
478
|
-
[..._sliceInstanceProperty(selectedColumns).call(selectedColumns, 0, dragResult.source.index), ..._sliceInstanceProperty(selectedColumns).call(selectedColumns, dragResult.source.index + 1)] : selectedColumns;
|
|
479
|
-
const columns = isSwap ? selectedColumns : availableColumns;
|
|
480
|
-
const draggedColumn = _findInstanceProperty(columns).call(columns, col => col.key === dragResult.draggableId);
|
|
481
|
-
|
|
482
|
-
// push the column in the new position if draggedColumn is found
|
|
483
|
-
if (draggedColumn) {
|
|
484
|
-
onUpdateColumns([..._sliceInstanceProperty(items).call(items, 0, dragResult.destination.index), draggedColumn, ..._sliceInstanceProperty(items).call(items, dragResult.destination.index)]);
|
|
485
|
-
}
|
|
486
|
-
}
|
|
487
|
-
};
|
|
488
|
-
const DropdownIndicator = () => jsx(Spacings.Inline, {
|
|
489
|
-
alignItems: "center",
|
|
490
|
-
children: jsx(SearchIcon, {
|
|
491
|
-
size: "medium",
|
|
492
|
-
color: "primary"
|
|
493
|
-
})
|
|
494
|
-
});
|
|
495
|
-
DropdownIndicator.displayName = 'DropdownIndicator';
|
|
496
|
-
const Nothing = () => null;
|
|
497
|
-
const selectInputComponents = {
|
|
498
|
-
Option: Nothing,
|
|
499
|
-
Menu: Nothing,
|
|
500
|
-
DropdownIndicator
|
|
501
|
-
};
|
|
502
|
-
const ColumnSettingsManager = props => {
|
|
503
|
-
if (props.areHiddenColumnsSearchable) {
|
|
504
|
-
process.env.NODE_ENV !== "production" ? warning(typeof props.searchHiddenColumns !== 'undefined', 'ui-kit/ColumnSettingsManager: "searchHiddenColumns" must be provided when "areHiddenColumnsSearchable" is true') : void 0;
|
|
505
|
-
}
|
|
506
|
-
const intl = useIntl();
|
|
507
|
-
const _useState = useState(false),
|
|
508
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
509
|
-
isDragging = _useState2[0],
|
|
510
|
-
setIsDragging = _useState2[1];
|
|
511
|
-
const searchHiddenColumns = props.searchHiddenColumns;
|
|
512
|
-
const handleDragStart = () => {
|
|
513
|
-
setIsDragging(true);
|
|
514
|
-
};
|
|
515
|
-
const hiddenColumns = useMemo(() => differenceWith(props.availableColumns, props.selectedColumns, (a, b) => a.key === b.key), [props.availableColumns, props.selectedColumns]);
|
|
516
|
-
const handleDragEnd = useCallback(dragResult => handleColumnsUpdate(dragResult, props.onUpdateColumns, props.selectedColumns, props.availableColumns, setIsDragging), [props.onUpdateColumns, props.selectedColumns, props.availableColumns]);
|
|
517
|
-
const debouncedSearchHiddenColumns = useMemo(() => debounce(searchHiddenColumns !== null && searchHiddenColumns !== void 0 ? searchHiddenColumns : noSearch, 300), [searchHiddenColumns]);
|
|
518
|
-
const handleInputChange = useCallback(inputValue => debouncedSearchHiddenColumns(inputValue), [debouncedSearchHiddenColumns]);
|
|
519
|
-
return jsx(SettingsContainer$1, {
|
|
520
|
-
title: messages$1.title,
|
|
521
|
-
closeButtonLabel: messages$1.closeButtonLabel,
|
|
522
|
-
onClose: props.onClose,
|
|
523
|
-
primaryButton: props.primaryButton,
|
|
524
|
-
secondaryButton: props.secondaryButton,
|
|
525
|
-
containerTheme: props.managerTheme,
|
|
526
|
-
children: jsx(DragDropContext, {
|
|
527
|
-
onDragEnd: handleDragEnd,
|
|
528
|
-
onDragStart: handleDragStart,
|
|
529
|
-
children: jsxs(Spacings.Inline, {
|
|
530
|
-
scale: "l",
|
|
531
|
-
children: [jsx(DroppableContainer, {
|
|
532
|
-
isDragging: isDragging,
|
|
533
|
-
"aria-labelledby": "hidden-columns",
|
|
534
|
-
children: jsxs(Spacings.Stack, {
|
|
535
|
-
scale: "m",
|
|
536
|
-
children: [jsxs(Spacings.Inline, {
|
|
537
|
-
scale: "s",
|
|
538
|
-
alignItems: "center",
|
|
539
|
-
children: [jsx(EyeCrossedIcon, {
|
|
540
|
-
size: "big"
|
|
541
|
-
}), jsx(FieldLabel, {
|
|
542
|
-
id: "hidden-columns",
|
|
543
|
-
title: intl.formatMessage(messages$1.hiddenColumns)
|
|
544
|
-
})]
|
|
545
|
-
}), props.areHiddenColumnsSearchable && jsx(AsyncSelectInput, _objectSpread$2(_objectSpread$2({}, props.searchHiddenColumnsPlaceholder ? {
|
|
546
|
-
placeholder: props.searchHiddenColumnsPlaceholder
|
|
547
|
-
} : undefined), {}, {
|
|
548
|
-
onChange: voidChangeHandler,
|
|
549
|
-
loadOptions: noSearch,
|
|
550
|
-
onInputChange: handleInputChange,
|
|
551
|
-
components: selectInputComponents
|
|
552
|
-
})), jsx(DroppablePanel$1, {
|
|
553
|
-
droppableId: HIDDEN_COLUMNS_PANEL,
|
|
554
|
-
"data-testid": HIDDEN_COLUMNS_PANEL,
|
|
555
|
-
noColumnsText: intl.formatMessage(messages$1.noHiddenColumnsToShow),
|
|
556
|
-
columns: hiddenColumns,
|
|
557
|
-
isSearchable: props.areHiddenColumnsSearchable
|
|
558
|
-
})]
|
|
559
|
-
})
|
|
560
|
-
}), jsx(DroppableContainer, {
|
|
561
|
-
isDragging: isDragging,
|
|
562
|
-
"aria-labelledby": "visible-columns",
|
|
563
|
-
children: jsxs(Spacings.Stack, {
|
|
564
|
-
scale: "m",
|
|
565
|
-
children: [jsxs(Spacings.Inline, {
|
|
566
|
-
scale: "xs",
|
|
567
|
-
alignItems: "center",
|
|
568
|
-
children: [jsx(EyeIcon, {
|
|
569
|
-
size: "medium"
|
|
570
|
-
}), jsx(FieldLabel, {
|
|
571
|
-
id: "visible-columns",
|
|
572
|
-
title: intl.formatMessage(messages$1.visibleColumns)
|
|
573
|
-
})]
|
|
574
|
-
}), jsx(DroppablePanel$1, {
|
|
575
|
-
droppableId: SELECTED_COLUMNS_PANEL,
|
|
576
|
-
"data-testid": SELECTED_COLUMNS_PANEL,
|
|
577
|
-
noColumnsText: intl.formatMessage(messages$1.noSelectedColumnsToShow),
|
|
578
|
-
columns: props.selectedColumns,
|
|
579
|
-
onRemove: props.onUpdateColumns
|
|
580
|
-
})]
|
|
581
|
-
})
|
|
582
|
-
})]
|
|
583
|
-
})
|
|
207
|
+
const CustomSettingsManager = props => {
|
|
208
|
+
return jsx(Fragment, {
|
|
209
|
+
children: jsx(SettingsContainer, {
|
|
210
|
+
customSettingsTitle: props.customPanelTitle,
|
|
211
|
+
closeButtonLabel: messages$1.closeButtonLabel,
|
|
212
|
+
onClose: props.onClose,
|
|
213
|
+
containerTheme: props.managerTheme,
|
|
214
|
+
children: props.children
|
|
584
215
|
})
|
|
585
216
|
});
|
|
586
217
|
};
|
|
587
|
-
|
|
588
|
-
availableColumns: _pt.arrayOf(_pt.shape({
|
|
589
|
-
key: _pt.string.isRequired,
|
|
590
|
-
label: _pt.node.isRequired
|
|
591
|
-
})).isRequired,
|
|
592
|
-
selectedColumns: _pt.arrayOf(_pt.shape({
|
|
593
|
-
key: _pt.string.isRequired,
|
|
594
|
-
label: _pt.node.isRequired
|
|
595
|
-
})).isRequired,
|
|
596
|
-
onUpdateColumns: _pt.func.isRequired,
|
|
597
|
-
areHiddenColumnsSearchable: _pt.bool,
|
|
598
|
-
searchHiddenColumns: _pt.func,
|
|
599
|
-
searchHiddenColumnsPlaceholder: _pt.string,
|
|
218
|
+
CustomSettingsManager.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
600
219
|
onClose: _pt.func.isRequired,
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
220
|
+
managerTheme: _pt.oneOf(['light', 'dark']),
|
|
221
|
+
children: _pt.node.isRequired,
|
|
222
|
+
customPanelTitle: _pt.oneOfType([_pt.string, _pt.any]).isRequired
|
|
604
223
|
} : {};
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
availableColumns: []
|
|
608
|
-
};
|
|
609
|
-
ColumnSettingsManager.defaultProps = defaultProps;
|
|
610
|
-
var ColumnSettingsManager$1 = ColumnSettingsManager;
|
|
224
|
+
CustomSettingsManager.displayName = 'CustomSettingsManager';
|
|
225
|
+
var CustomSettingsManager$1 = CustomSettingsManager;
|
|
611
226
|
|
|
612
227
|
var messages = defineMessages({
|
|
613
228
|
placeholder: {
|
|
@@ -628,7 +243,7 @@ var messages = defineMessages({
|
|
|
628
243
|
});
|
|
629
244
|
|
|
630
245
|
function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
631
|
-
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
246
|
+
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context4, _context5; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context4 = ownKeys$1(Object(t), !0)).call(_context4, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context5 = ownKeys$1(Object(t))).call(_context5, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
632
247
|
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)."; }
|
|
633
248
|
const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
634
249
|
target: "e3i1gnv0"
|
|
@@ -641,20 +256,33 @@ const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
641
256
|
} : {
|
|
642
257
|
name: "1ff36h2",
|
|
643
258
|
styles: "flex-grow:1",
|
|
644
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAiCkC","file":"data-table-settings.tsx","sourcesContent":["import { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport { ColumnsIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\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';\nimport DropdownMenu from '@commercetools-uikit/dropdown-menu';\nimport IconButton from '@commercetools-uikit/icon-button';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport { TColumnData, TDataTableSettingsProps } from '../types';\n\nexport type TSelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDropdownOption = {\n  value: string;\n  label: string;\n};\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  formatMessage,\n}: {\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => [\n  ...(areColumnSettingsEnabled\n    ? [\n        {\n          value: COLUMN_MANAGER,\n          label: formatMessage(messages.columnManagerOption),\n        },\n      ]\n    : []),\n  ...(areDisplaySettingsEnabled\n    ? [\n        {\n          value: DISPLAY_SETTINGS,\n          label: formatMessage(messages.displaySettingsOption),\n        },\n      ]\n    : []),\n];\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n  const dropdownOptions: TDropdownOption[] = getDropdownOptions({\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    formatMessage: intl.formatMessage,\n  });\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale=\"xs\">\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <Tooltip\n            placement=\"left\"\n            title={intl.formatMessage(messages.placeholder)}\n          >\n            <DropdownMenu\n              triggerElement={\n                <IconButton\n                  icon={<ColumnsIcon />}\n                  label=\"Open table manager dropdown\"\n                />\n              }\n              menuHorizontalConstraint={'auto'}\n              menuPosition=\"right\"\n              menuType=\"list\"\n            >\n              {dropdownOptions?.map((option: TDropdownOption) => (\n                <DropdownMenu.ListMenuItem\n                  key={option?.label}\n                  onClick={() => {\n                    setOpenedPanelId(option?.value);\n                  }}\n                >\n                  {option?.label}\n                </DropdownMenu.ListMenuItem>\n              ))}\n            </DropdownMenu>\n          </Tooltip>\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      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          availableColumns={props.columnManager?.hideableColumns ?? []}\n          selectedColumns={selectedColumns}\n          onClose={handleSettingsPanelChange}\n          onUpdateColumns={(nextVisibleColumns) => {\n            const keysOfVisibleColumns = nextVisibleColumns.map(\n              (visibleColumn) => visibleColumn.key\n            );\n            props.onSettingsChange?.(\n              UPDATE_ACTIONS.COLUMNS_UPDATE,\n              keysOfVisibleColumns\n            );\n          }}\n          managerTheme={props.managerTheme}\n        />\n      )}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
|
|
259
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAsCkC","file":"data-table-settings.tsx","sourcesContent":["import { useState } from 'react';\nimport { warning } from '@commercetools-uikit/utils';\nimport { useIntl, type MessageDescriptor } from 'react-intl';\nimport styled from '@emotion/styled';\nimport { ColumnsIcon } from '@commercetools-uikit/icons';\nimport Spacings from '@commercetools-uikit/spacings';\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 CustomSettingsManager from '../custom-settings-manager';\nimport messages from './messages';\nimport DropdownMenu from '@commercetools-uikit/dropdown-menu';\nimport IconButton from '@commercetools-uikit/icon-button';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  TColumnData,\n  TDataTableSettingsProps,\n  TCustomSettingsProps,\n} from '../types';\n\nexport type TSelectChangeEvent = {\n  target: {\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist: () => void;\n};\n\ntype MappedColumns = Record<string, TColumnData>;\n\nexport type TDropdownOption = {\n  value: string;\n  label: string;\n};\n\nconst TopBarContainer = styled.div`\n  flex-grow: 1;\n`;\n\nexport const getDropdownOptions = ({\n  areCustomColumnSettingsEnabled,\n  areColumnSettingsEnabled,\n  areDisplaySettingsEnabled,\n  customSettings,\n  columnManagerLabel,\n  displaySettingsLabel,\n  formatMessage,\n}: {\n  areCustomColumnSettingsEnabled: boolean;\n  areColumnSettingsEnabled: boolean;\n  areDisplaySettingsEnabled: boolean;\n  customSettings?: TCustomSettingsProps[];\n  columnManagerLabel?: string;\n  displaySettingsLabel?: string;\n  formatMessage: (message: MessageDescriptor) => string;\n}) => {\n  return [\n    ...(areColumnSettingsEnabled\n      ? [\n          {\n            value: COLUMN_MANAGER,\n            label: columnManagerLabel\n              ? columnManagerLabel\n              : formatMessage(messages.columnManagerOption),\n          },\n        ]\n      : []),\n    ...(customSettings\n      ? Object.entries(customSettings).map(([key, customSetting]) => {\n          return customSetting.type === COLUMN_MANAGER &&\n            !areCustomColumnSettingsEnabled\n            ? undefined\n            : {\n                value: key,\n                label: customSetting.customPanelTitle,\n              };\n        })\n      : []),\n    ...(areDisplaySettingsEnabled\n      ? [\n          {\n            value: DISPLAY_SETTINGS,\n            label: displaySettingsLabel\n              ? displaySettingsLabel\n              : formatMessage(messages.displaySettingsOption),\n          },\n        ]\n      : []),\n  ].filter((option) => option !== undefined);\n};\n\nexport const getMappedColumns = (columns: TColumnData[] = []) =>\n  columns.reduce<MappedColumns>(\n    (mappedColumns, column) => ({\n      ...mappedColumns,\n      [column.key]: column,\n    }),\n    {}\n  );\n\nexport const getSelectedColumns = (\n  mappedColumns: MappedColumns,\n  visibleColumnsKeys: string[] = []\n) => visibleColumnsKeys.map((columnKey) => mappedColumns[columnKey]);\n\nconst DataTableSettings = (props: TDataTableSettingsProps) => {\n  const areDisplaySettingsEnabled = Boolean(\n    props.displaySettings && !props.displaySettings.disableDisplaySettings\n  );\n  const areColumnSettingsEnabled = Boolean(\n    props.columnManager && !props.columnManager.disableColumnManager\n  );\n\n  const areCustomColumnSettingsEnabled = Boolean(\n    props.customColumnManager &&\n      !props.customColumnManager?.disableCustomColumnManager\n  );\n\n  warning(\n    areDisplaySettingsEnabled || areColumnSettingsEnabled\n      ? typeof props.onSettingsChange === 'function'\n      : true,\n    `ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.`\n  );\n\n  const intl = useIntl();\n  const [openedPanelId, setOpenedPanelId] = useState<string | null | undefined>(\n    null\n  );\n\n  const dropdownOptions: TDropdownOption[] = getDropdownOptions({\n    areCustomColumnSettingsEnabled,\n    areDisplaySettingsEnabled,\n    areColumnSettingsEnabled,\n    customSettings: props.customSettings,\n    columnManagerLabel: props.columnManager?.columnManagerLabel,\n    displaySettingsLabel: props.displaySettings?.displaySettingsLabel,\n    formatMessage: intl.formatMessage,\n  });\n\n  const mappedColumns = getMappedColumns(\n    areColumnSettingsEnabled ? props.columnManager!.hideableColumns : undefined\n  );\n\n  const selectedColumns = getSelectedColumns(\n    mappedColumns,\n    areColumnSettingsEnabled\n      ? props.columnManager!.visibleColumnKeys\n      : undefined\n  );\n\n  const handleSettingsPanelChange = () => setOpenedPanelId(null);\n\n  return (\n    <Spacings.Stack scale=\"xs\">\n      <Spacings.Inline justifyContent=\"space-between\" alignItems=\"center\">\n        <TopBarContainer>{props.topBar}</TopBarContainer>\n        {dropdownOptions.length > 0 && (\n          <Tooltip\n            placement=\"left\"\n            title={intl.formatMessage(messages.placeholder)}\n          >\n            <DropdownMenu\n              triggerElement={\n                <IconButton\n                  icon={<ColumnsIcon />}\n                  label=\"Open table manager dropdown\"\n                />\n              }\n              menuHorizontalConstraint={'auto'}\n              menuPosition=\"right\"\n              menuType=\"list\"\n            >\n              {dropdownOptions?.map((option: TDropdownOption) => (\n                <DropdownMenu.ListMenuItem\n                  key={option?.label}\n                  onClick={() => {\n                    setOpenedPanelId(option?.value);\n                  }}\n                >\n                  {option?.label}\n                </DropdownMenu.ListMenuItem>\n              ))}\n            </DropdownMenu>\n          </Tooltip>\n        )}\n      </Spacings.Inline>\n      {openedPanelId === DISPLAY_SETTINGS && (\n        <DisplaySettingsManager\n          {...(props.displaySettings || {})}\n          title={props.displaySettings?.displaySettingsLabel}\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      {openedPanelId === COLUMN_MANAGER && (\n        <ColumnSettingsManager\n          {...(props.columnManager || {})}\n          title={props.columnManager?.columnManagerLabel}\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      {props.customSettings &&\n        Object.entries(props.customSettings).map(([key, customSetting]) => {\n          if (!customSetting.key) {\n            throw new Error(\n              'ui-kit/DataTableManager: missing: `key` prop, `customSettings` must be a JSON in the format Record<string, Object>.'\n            );\n          }\n          const CustomComponent = customSetting.customComponent;\n          return (\n            key === openedPanelId && (\n              <div key={customSetting.key}>\n                {customSetting.type === COLUMN_MANAGER ? (\n                  CustomComponent && (\n                    <CustomComponent\n                      {...(customSetting || {})}\n                      additionalSettings={{\n                        ...customSetting,\n                        ...props.additionalSettings,\n                      }}\n                      onClose={handleSettingsPanelChange}\n                      managerTheme={props.managerTheme}\n                      selectedColumns={props.selectedColumns}\n                      availableColumns={props.customColumnManager ?? undefined}\n                      onUpdateColumns={(nextVisibleColumns, key) => {\n                        const keysOfVisibleColumns = nextVisibleColumns.map(\n                          (visibleColumn) => visibleColumn.key\n                        );\n                        props.onSettingsChange?.(\n                          UPDATE_ACTIONS.CUSTOM_COLUMNS_UPDATE,\n                          keysOfVisibleColumns,\n                          key\n                        );\n                      }}\n                    />\n                  )\n                ) : (\n                  <CustomSettingsManager\n                    {...(customSetting || {})}\n                    onClose={handleSettingsPanelChange}\n                    managerTheme={props.managerTheme}\n                  >\n                    {CustomComponent && (\n                      <CustomComponent\n                        updateCustomSettings={(settings) => {\n                          props.onSettingsChange?.(\n                            UPDATE_ACTIONS.CUSTOM_SETTINGS_UPDATE,\n                            settings\n                          );\n                        }}\n                        additionalSettings={{\n                          ...customSetting,\n                          ...props.additionalSettings,\n                        }}\n                      />\n                    )}\n                  </CustomSettingsManager>\n                )}\n              </div>\n            )\n          );\n        })}\n    </Spacings.Stack>\n  );\n};\n\nDataTableSettings.displayName = 'DataTableSettings';\n\nexport default DataTableSettings;\n"]} */",
|
|
645
260
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
646
261
|
});
|
|
647
262
|
const getDropdownOptions = _ref => {
|
|
648
|
-
|
|
263
|
+
var _context, _context2;
|
|
264
|
+
let areCustomColumnSettingsEnabled = _ref.areCustomColumnSettingsEnabled,
|
|
265
|
+
areColumnSettingsEnabled = _ref.areColumnSettingsEnabled,
|
|
649
266
|
areDisplaySettingsEnabled = _ref.areDisplaySettingsEnabled,
|
|
267
|
+
customSettings = _ref.customSettings,
|
|
268
|
+
columnManagerLabel = _ref.columnManagerLabel,
|
|
269
|
+
displaySettingsLabel = _ref.displaySettingsLabel,
|
|
650
270
|
formatMessage = _ref.formatMessage;
|
|
651
|
-
return [...(areColumnSettingsEnabled ? [{
|
|
271
|
+
return _filterInstanceProperty(_context = [...(areColumnSettingsEnabled ? [{
|
|
652
272
|
value: COLUMN_MANAGER,
|
|
653
|
-
label: formatMessage(messages.columnManagerOption)
|
|
654
|
-
}] : []), ...(
|
|
273
|
+
label: columnManagerLabel ? columnManagerLabel : formatMessage(messages.columnManagerOption)
|
|
274
|
+
}] : []), ...(customSettings ? _mapInstanceProperty(_context2 = _Object$entries(customSettings)).call(_context2, _ref2 => {
|
|
275
|
+
let _ref3 = _slicedToArray(_ref2, 2),
|
|
276
|
+
key = _ref3[0],
|
|
277
|
+
customSetting = _ref3[1];
|
|
278
|
+
return customSetting.type === COLUMN_MANAGER && !areCustomColumnSettingsEnabled ? undefined : {
|
|
279
|
+
value: key,
|
|
280
|
+
label: customSetting.customPanelTitle
|
|
281
|
+
};
|
|
282
|
+
}) : []), ...(areDisplaySettingsEnabled ? [{
|
|
655
283
|
value: DISPLAY_SETTINGS,
|
|
656
|
-
label: formatMessage(messages.displaySettingsOption)
|
|
657
|
-
}] : [])];
|
|
284
|
+
label: displaySettingsLabel ? displaySettingsLabel : formatMessage(messages.displaySettingsOption)
|
|
285
|
+
}] : [])]).call(_context, option => option !== undefined);
|
|
658
286
|
};
|
|
659
287
|
const getMappedColumns = function () {
|
|
660
288
|
let columns = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
@@ -667,9 +295,10 @@ const getSelectedColumns = function (mappedColumns) {
|
|
|
667
295
|
return _mapInstanceProperty(visibleColumnsKeys).call(visibleColumnsKeys, columnKey => mappedColumns[columnKey]);
|
|
668
296
|
};
|
|
669
297
|
const DataTableSettings = props => {
|
|
670
|
-
var _props$columnManager$, _props$
|
|
298
|
+
var _props$customColumnMa, _props$columnManager, _props$displaySetting, _props$displaySetting2, _props$columnManager2, _props$columnManager$, _props$columnManager3, _context3;
|
|
671
299
|
const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
|
|
672
300
|
const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
|
|
301
|
+
const areCustomColumnSettingsEnabled = Boolean(props.customColumnManager && !((_props$customColumnMa = props.customColumnManager) !== null && _props$customColumnMa !== void 0 && _props$customColumnMa.disableCustomColumnManager));
|
|
673
302
|
process.env.NODE_ENV !== "production" ? warning(areDisplaySettingsEnabled || areColumnSettingsEnabled ? typeof props.onSettingsChange === 'function' : true, "ui-kit/DataTableManager: the prop \"onSettingsChange\" is required when either the display settings or the column settings are enabled.") : void 0;
|
|
674
303
|
const intl = useIntl();
|
|
675
304
|
const _useState = useState(null),
|
|
@@ -677,8 +306,12 @@ const DataTableSettings = props => {
|
|
|
677
306
|
openedPanelId = _useState2[0],
|
|
678
307
|
setOpenedPanelId = _useState2[1];
|
|
679
308
|
const dropdownOptions = getDropdownOptions({
|
|
309
|
+
areCustomColumnSettingsEnabled,
|
|
680
310
|
areDisplaySettingsEnabled,
|
|
681
311
|
areColumnSettingsEnabled,
|
|
312
|
+
customSettings: props.customSettings,
|
|
313
|
+
columnManagerLabel: (_props$columnManager = props.columnManager) === null || _props$columnManager === void 0 ? void 0 : _props$columnManager.columnManagerLabel,
|
|
314
|
+
displaySettingsLabel: (_props$displaySetting = props.displaySettings) === null || _props$displaySetting === void 0 ? void 0 : _props$displaySetting.displaySettingsLabel,
|
|
682
315
|
formatMessage: intl.formatMessage
|
|
683
316
|
});
|
|
684
317
|
const mappedColumns = getMappedColumns(areColumnSettingsEnabled ? props.columnManager.hideableColumns : undefined);
|
|
@@ -711,6 +344,7 @@ const DataTableSettings = props => {
|
|
|
711
344
|
})
|
|
712
345
|
})]
|
|
713
346
|
}), openedPanelId === DISPLAY_SETTINGS && jsx(DisplaySettingsManager, _objectSpread$1(_objectSpread$1({}, props.displaySettings || {}), {}, {
|
|
347
|
+
title: (_props$displaySetting2 = props.displaySettings) === null || _props$displaySetting2 === void 0 ? void 0 : _props$displaySetting2.displaySettingsLabel,
|
|
714
348
|
onClose: handleSettingsPanelChange,
|
|
715
349
|
onDensityDisplayChange: event => {
|
|
716
350
|
var _props$onSettingsChan;
|
|
@@ -721,8 +355,9 @@ const DataTableSettings = props => {
|
|
|
721
355
|
(_props$onSettingsChan2 = props.onSettingsChange) === null || _props$onSettingsChan2 === void 0 || _props$onSettingsChan2.call(props, UPDATE_ACTIONS.IS_TABLE_WRAPPING_TEXT_UPDATE, event.target.value === SHOW_HIDE_ON_DEMAND);
|
|
722
356
|
},
|
|
723
357
|
managerTheme: props.managerTheme
|
|
724
|
-
})), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager
|
|
725
|
-
|
|
358
|
+
})), openedPanelId === COLUMN_MANAGER && jsx(ColumnSettingsManager, _objectSpread$1(_objectSpread$1({}, props.columnManager || {}), {}, {
|
|
359
|
+
title: (_props$columnManager2 = props.columnManager) === null || _props$columnManager2 === void 0 ? void 0 : _props$columnManager2.columnManagerLabel,
|
|
360
|
+
availableColumns: (_props$columnManager$ = (_props$columnManager3 = props.columnManager) === null || _props$columnManager3 === void 0 ? void 0 : _props$columnManager3.hideableColumns) !== null && _props$columnManager$ !== void 0 ? _props$columnManager$ : [],
|
|
726
361
|
selectedColumns: selectedColumns,
|
|
727
362
|
onClose: handleSettingsPanelChange,
|
|
728
363
|
onUpdateColumns: nextVisibleColumns => {
|
|
@@ -731,7 +366,40 @@ const DataTableSettings = props => {
|
|
|
731
366
|
(_props$onSettingsChan3 = props.onSettingsChange) === null || _props$onSettingsChan3 === void 0 || _props$onSettingsChan3.call(props, UPDATE_ACTIONS.COLUMNS_UPDATE, keysOfVisibleColumns);
|
|
732
367
|
},
|
|
733
368
|
managerTheme: props.managerTheme
|
|
734
|
-
}))
|
|
369
|
+
})), props.customSettings && _mapInstanceProperty(_context3 = _Object$entries(props.customSettings)).call(_context3, _ref4 => {
|
|
370
|
+
var _props$customColumnMa2;
|
|
371
|
+
let _ref5 = _slicedToArray(_ref4, 2),
|
|
372
|
+
key = _ref5[0],
|
|
373
|
+
customSetting = _ref5[1];
|
|
374
|
+
if (!customSetting.key) {
|
|
375
|
+
throw new Error('ui-kit/DataTableManager: missing: `key` prop, `customSettings` must be a JSON in the format Record<string, Object>.');
|
|
376
|
+
}
|
|
377
|
+
const CustomComponent = customSetting.customComponent;
|
|
378
|
+
return key === openedPanelId && jsx("div", {
|
|
379
|
+
children: customSetting.type === COLUMN_MANAGER ? CustomComponent && jsx(CustomComponent, _objectSpread$1(_objectSpread$1({}, customSetting || {}), {}, {
|
|
380
|
+
additionalSettings: _objectSpread$1(_objectSpread$1({}, customSetting), props.additionalSettings),
|
|
381
|
+
onClose: handleSettingsPanelChange,
|
|
382
|
+
managerTheme: props.managerTheme,
|
|
383
|
+
selectedColumns: props.selectedColumns,
|
|
384
|
+
availableColumns: (_props$customColumnMa2 = props.customColumnManager) !== null && _props$customColumnMa2 !== void 0 ? _props$customColumnMa2 : undefined,
|
|
385
|
+
onUpdateColumns: (nextVisibleColumns, key) => {
|
|
386
|
+
var _props$onSettingsChan4;
|
|
387
|
+
const keysOfVisibleColumns = _mapInstanceProperty(nextVisibleColumns).call(nextVisibleColumns, visibleColumn => visibleColumn.key);
|
|
388
|
+
(_props$onSettingsChan4 = props.onSettingsChange) === null || _props$onSettingsChan4 === void 0 || _props$onSettingsChan4.call(props, UPDATE_ACTIONS.CUSTOM_COLUMNS_UPDATE, keysOfVisibleColumns, key);
|
|
389
|
+
}
|
|
390
|
+
})) : jsx(CustomSettingsManager$1, _objectSpread$1(_objectSpread$1({}, customSetting || {}), {}, {
|
|
391
|
+
onClose: handleSettingsPanelChange,
|
|
392
|
+
managerTheme: props.managerTheme,
|
|
393
|
+
children: CustomComponent && jsx(CustomComponent, {
|
|
394
|
+
updateCustomSettings: settings => {
|
|
395
|
+
var _props$onSettingsChan5;
|
|
396
|
+
(_props$onSettingsChan5 = props.onSettingsChange) === null || _props$onSettingsChan5 === void 0 || _props$onSettingsChan5.call(props, UPDATE_ACTIONS.CUSTOM_SETTINGS_UPDATE, settings);
|
|
397
|
+
},
|
|
398
|
+
additionalSettings: _objectSpread$1(_objectSpread$1({}, customSetting), props.additionalSettings)
|
|
399
|
+
})
|
|
400
|
+
}))
|
|
401
|
+
}, customSetting.key);
|
|
402
|
+
})]
|
|
735
403
|
});
|
|
736
404
|
};
|
|
737
405
|
DataTableSettings.displayName = 'DataTableSettings';
|
|
@@ -746,6 +414,10 @@ const DataTableManager = props => {
|
|
|
746
414
|
const topBar = props.topBar || dataTableManagerContext.topBar;
|
|
747
415
|
const onSettingsChange = props.onSettingsChange || dataTableManagerContext.onSettingsChange;
|
|
748
416
|
const columnManager = props.columnManager || dataTableManagerContext.columnManager;
|
|
417
|
+
const customSettings = props.customSettings || dataTableManagerContext.customSettings;
|
|
418
|
+
const selectedColumns = props.selectedColumns || dataTableManagerContext.selectedColumns;
|
|
419
|
+
const customColumnManager = props.customColumnManager || dataTableManagerContext.customColumnManager;
|
|
420
|
+
const customColumns = props.customColumns || dataTableManagerContext.customColumns;
|
|
749
421
|
const areDisplaySettingsEnabled = Boolean(displaySettings && !displaySettings.disableDisplaySettings);
|
|
750
422
|
const isWrappingText = areDisplaySettingsEnabled && displaySettings.isWrappingText;
|
|
751
423
|
if (!dataTableColumns) {
|
|
@@ -754,15 +426,32 @@ const DataTableManager = props => {
|
|
|
754
426
|
const columns = useMemo(() => _mapInstanceProperty(dataTableColumns).call(dataTableColumns, column => _objectSpread(_objectSpread({}, column), {}, {
|
|
755
427
|
isTruncated: areDisplaySettingsEnabled ? isWrappingText : column.isTruncated
|
|
756
428
|
})), [dataTableColumns, areDisplaySettingsEnabled, isWrappingText]);
|
|
429
|
+
const _useState = useState({
|
|
430
|
+
key: ''
|
|
431
|
+
}),
|
|
432
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
433
|
+
additionalSettings = _useState2[0],
|
|
434
|
+
setAdditionalSettings = _useState2[1];
|
|
435
|
+
const additionalCustomSetting = dataTableManagerContext.additionalSettings || additionalSettings;
|
|
436
|
+
const updateSettings = additionalCustomSettings => {
|
|
437
|
+
setAdditionalSettings(additionalCustomSettings);
|
|
438
|
+
};
|
|
439
|
+
const updateCustomSettings = dataTableManagerContext.updateCustomSettings || updateSettings;
|
|
757
440
|
return jsxs(Spacings.Stack, {
|
|
758
441
|
children: [jsx(DataTableSettings$1, {
|
|
759
442
|
topBar: topBar,
|
|
760
443
|
onSettingsChange: onSettingsChange,
|
|
761
444
|
columnManager: columnManager,
|
|
762
445
|
displaySettings: displaySettings,
|
|
763
|
-
|
|
446
|
+
customSettings: customSettings,
|
|
447
|
+
managerTheme: "light",
|
|
448
|
+
additionalSettings: additionalCustomSetting,
|
|
449
|
+
updateCustomSettings: settings => updateCustomSettings(settings),
|
|
450
|
+
selectedColumns: selectedColumns !== null && selectedColumns !== void 0 ? selectedColumns : [],
|
|
451
|
+
customColumnManager: customColumnManager !== null && customColumnManager !== void 0 ? customColumnManager : undefined
|
|
764
452
|
}), props.children ? /*#__PURE__*/cloneElement(props.children, {
|
|
765
453
|
columns,
|
|
454
|
+
customColumns,
|
|
766
455
|
isCondensed: areDisplaySettingsEnabled && props.displaySettings.isCondensed
|
|
767
456
|
}) : null]
|
|
768
457
|
});
|
|
@@ -771,6 +460,6 @@ DataTableManager.displayName = 'DataTableManager';
|
|
|
771
460
|
var DataTableManager$1 = DataTableManager;
|
|
772
461
|
|
|
773
462
|
// NOTE: This string will be replaced on build time with the package version.
|
|
774
|
-
var version = "19.
|
|
463
|
+
var version = "19.11.0";
|
|
775
464
|
|
|
776
465
|
export { UPDATE_ACTIONS, DataTableManager$1 as default, version };
|