@commercetools-uikit/data-table-manager 19.12.1 → 19.13.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 CHANGED
@@ -68,7 +68,7 @@ export default Example;
68
68
 
69
69
  ### Detached
70
70
 
71
- As mentioned earlier, the default behaviour places the triggering element above the `<DataTable>` component (top-right corner), but there may be use cases where the triggering element needs to be positioned differently on the page. This is also possible but requires the usage of one more component (`DataTableManagerProvider`) in order to share the manager state between the manager panels and the `DataTable` component.
71
+ As mentioned earlier, the default behavior places the triggering element above the `<DataTable>` component (top-right corner), but there may be use cases where the triggering element needs to be positioned differently on the page. This is also possible but requires the usage of one more component (`DataTableManagerProvider`) in order to share the manager state between the manager panels and the `DataTable` component.
72
72
 
73
73
  In this mode, you should pass the manager props to the `DataTableManagerProvider` component and the `DataTableManager` does not need to receive any prop; it can be placed anywhere in the component's tree without requiring any prop.
74
74
 
@@ -110,6 +110,31 @@ const Example = () => (
110
110
  export default Example;
111
111
  ```
112
112
 
113
+ ### With custom configuration settings
114
+
115
+ The `DataTableManager` provides a feature for users to add custom configurations to the data table settings.
116
+
117
+ To configure the data table manager, you can pass in your own `jsx` component and all the expected actions and states you want to control.
118
+
119
+ The `ColumnSettingsManager` component is also exposed for users to consume and pass in configuration of choice for custom column configurations, pass in your settings through the `customColumnManager` props.
120
+
121
+ ```jsx
122
+ import { ColumnSettingsManager } from '@commercetools-uikit/data-table-manager/column-settings-manager';
123
+
124
+ <DataTableManagerProvider
125
+ columns={columns}
126
+ onSettingsChange={() => tableSettingsChangeHandler}
127
+ columnManager={columnManager}
128
+ displaySettings={displaySettings}
129
+ customSettings={customSettings}
130
+ selectedColumns={selectedColumns}
131
+ customColumnManager={customColumnManager}
132
+ customColumns={visibleCustomColumns}
133
+ >
134
+ <DataTable rows={rows} />
135
+ </DataTableManagerProvider>;
136
+ ```
137
+
113
138
  ## Properties
114
139
 
115
140
  | Props | Type | Required | Default | Description |
@@ -282,7 +282,7 @@ const TopBarContainer = /*#__PURE__*/_styled__default["default"]("div", process.
282
282
  } : {
283
283
  name: "1ff36h2",
284
284
  styles: "flex-grow:1",
285
- 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"]} */",
285
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAuCkC","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  isDisabled?: boolean;\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 !== undefined\n      ? [\n          {\n            value: COLUMN_MANAGER,\n            isDisabled: !areColumnSettingsEnabled,\n            label: columnManagerLabel\n              ? columnManagerLabel\n              : formatMessage(messages.columnManagerOption),\n          },\n        ]\n      : []),\n    ...(customSettings && areCustomColumnSettingsEnabled !== undefined\n      ? Object.entries(customSettings).map(([key, customSetting]) => {\n          return customSetting.type === COLUMN_MANAGER &&\n            Object.keys(customSetting).length > 0 &&\n            !areCustomColumnSettingsEnabled\n            ? {\n                value: key,\n                label: customSetting.customPanelTitle,\n                isDisabled: true,\n              }\n            : {\n                value: key,\n                label: customSetting.customPanelTitle,\n              };\n        })\n      : []),\n    ...(areDisplaySettingsEnabled !== undefined\n      ? [\n          {\n            value: DISPLAY_SETTINGS,\n            isDisabled: !areDisplaySettingsEnabled,\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 getEnabledDisplaySettings = () => {\n    if (!props.displaySettings || Object.keys(props.displaySettings).length < 0)\n      return undefined;\n\n    return Boolean(\n      props.displaySettings && !props.displaySettings.disableDisplaySettings\n    );\n  };\n  const getEnabledColumnSettings = () => {\n    if (!props.columnManager || Object.keys(props.columnManager).length < 0)\n      return undefined;\n\n    return Boolean(\n      props.columnManager && !props.columnManager.disableColumnManager\n    );\n  };\n  const areDisplaySettingsEnabled = getEnabledDisplaySettings();\n  const areColumnSettingsEnabled = getEnabledColumnSettings();\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                  isDisabled={option?.isDisabled}\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"]} */",
286
286
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
287
287
  });
288
288
  const getDropdownOptions = _ref => {
@@ -294,19 +294,25 @@ const getDropdownOptions = _ref => {
294
294
  columnManagerLabel = _ref.columnManagerLabel,
295
295
  displaySettingsLabel = _ref.displaySettingsLabel,
296
296
  formatMessage = _ref.formatMessage;
297
- return _filterInstanceProperty__default["default"](_context = [...(areColumnSettingsEnabled ? [{
297
+ return _filterInstanceProperty__default["default"](_context = [...(areColumnSettingsEnabled !== undefined ? [{
298
298
  value: COLUMN_MANAGER,
299
+ isDisabled: !areColumnSettingsEnabled,
299
300
  label: columnManagerLabel ? columnManagerLabel : formatMessage(messages.columnManagerOption)
300
- }] : []), ...(customSettings ? _mapInstanceProperty__default["default"](_context2 = _Object$entries__default["default"](customSettings)).call(_context2, _ref2 => {
301
+ }] : []), ...(customSettings && areCustomColumnSettingsEnabled !== undefined ? _mapInstanceProperty__default["default"](_context2 = _Object$entries__default["default"](customSettings)).call(_context2, _ref2 => {
301
302
  let _ref3 = _slicedToArray(_ref2, 2),
302
303
  key = _ref3[0],
303
304
  customSetting = _ref3[1];
304
- return customSetting.type === COLUMN_MANAGER && !areCustomColumnSettingsEnabled ? undefined : {
305
+ return customSetting.type === COLUMN_MANAGER && _Object$keys__default["default"](customSetting).length > 0 && !areCustomColumnSettingsEnabled ? {
306
+ value: key,
307
+ label: customSetting.customPanelTitle,
308
+ isDisabled: true
309
+ } : {
305
310
  value: key,
306
311
  label: customSetting.customPanelTitle
307
312
  };
308
- }) : []), ...(areDisplaySettingsEnabled ? [{
313
+ }) : []), ...(areDisplaySettingsEnabled !== undefined ? [{
309
314
  value: DISPLAY_SETTINGS,
315
+ isDisabled: !areDisplaySettingsEnabled,
310
316
  label: displaySettingsLabel ? displaySettingsLabel : formatMessage(messages.displaySettingsOption)
311
317
  }] : [])]).call(_context, option => option !== undefined);
312
318
  };
@@ -322,8 +328,16 @@ const getSelectedColumns = function (mappedColumns) {
322
328
  };
323
329
  const DataTableSettings = props => {
324
330
  var _context3;
325
- const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
326
- const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
331
+ const getEnabledDisplaySettings = () => {
332
+ if (!props.displaySettings || _Object$keys__default["default"](props.displaySettings).length < 0) return undefined;
333
+ return Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
334
+ };
335
+ const getEnabledColumnSettings = () => {
336
+ if (!props.columnManager || _Object$keys__default["default"](props.columnManager).length < 0) return undefined;
337
+ return Boolean(props.columnManager && !props.columnManager.disableColumnManager);
338
+ };
339
+ const areDisplaySettingsEnabled = getEnabledDisplaySettings();
340
+ const areColumnSettingsEnabled = getEnabledColumnSettings();
327
341
  const areCustomColumnSettingsEnabled = Boolean(props.customColumnManager && !props.customColumnManager?.disableCustomColumnManager);
328
342
  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;
329
343
  const intl = reactIntl.useIntl();
@@ -365,6 +379,7 @@ const DataTableSettings = props => {
365
379
  onClick: () => {
366
380
  setOpenedPanelId(option?.value);
367
381
  },
382
+ isDisabled: option?.isDisabled,
368
383
  children: option?.label
369
384
  }, option?.label))
370
385
  })
@@ -480,7 +495,7 @@ DataTableManager.displayName = 'DataTableManager';
480
495
  var DataTableManager$1 = DataTableManager;
481
496
 
482
497
  // NOTE: This string will be replaced on build time with the package version.
483
- var version = "19.12.1";
498
+ var version = "19.13.0";
484
499
 
485
500
  exports.ColumnSettingsManager = columnSettingsManager.ColumnSettingsManager;
486
501
  Object.defineProperty(exports, 'useRowSelection', {
@@ -269,19 +269,25 @@ const getDropdownOptions = _ref => {
269
269
  columnManagerLabel = _ref.columnManagerLabel,
270
270
  displaySettingsLabel = _ref.displaySettingsLabel,
271
271
  formatMessage = _ref.formatMessage;
272
- return _filterInstanceProperty__default["default"](_context = [...(areColumnSettingsEnabled ? [{
272
+ return _filterInstanceProperty__default["default"](_context = [...(areColumnSettingsEnabled !== undefined ? [{
273
273
  value: COLUMN_MANAGER,
274
+ isDisabled: !areColumnSettingsEnabled,
274
275
  label: columnManagerLabel ? columnManagerLabel : formatMessage(messages.columnManagerOption)
275
- }] : []), ...(customSettings ? _mapInstanceProperty__default["default"](_context2 = _Object$entries__default["default"](customSettings)).call(_context2, _ref2 => {
276
+ }] : []), ...(customSettings && areCustomColumnSettingsEnabled !== undefined ? _mapInstanceProperty__default["default"](_context2 = _Object$entries__default["default"](customSettings)).call(_context2, _ref2 => {
276
277
  let _ref3 = _slicedToArray(_ref2, 2),
277
278
  key = _ref3[0],
278
279
  customSetting = _ref3[1];
279
- return customSetting.type === COLUMN_MANAGER && !areCustomColumnSettingsEnabled ? undefined : {
280
+ return customSetting.type === COLUMN_MANAGER && _Object$keys__default["default"](customSetting).length > 0 && !areCustomColumnSettingsEnabled ? {
281
+ value: key,
282
+ label: customSetting.customPanelTitle,
283
+ isDisabled: true
284
+ } : {
280
285
  value: key,
281
286
  label: customSetting.customPanelTitle
282
287
  };
283
- }) : []), ...(areDisplaySettingsEnabled ? [{
288
+ }) : []), ...(areDisplaySettingsEnabled !== undefined ? [{
284
289
  value: DISPLAY_SETTINGS,
290
+ isDisabled: !areDisplaySettingsEnabled,
285
291
  label: displaySettingsLabel ? displaySettingsLabel : formatMessage(messages.displaySettingsOption)
286
292
  }] : [])]).call(_context, option => option !== undefined);
287
293
  };
@@ -297,8 +303,16 @@ const getSelectedColumns = function (mappedColumns) {
297
303
  };
298
304
  const DataTableSettings = props => {
299
305
  var _context3;
300
- const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
301
- const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
306
+ const getEnabledDisplaySettings = () => {
307
+ if (!props.displaySettings || _Object$keys__default["default"](props.displaySettings).length < 0) return undefined;
308
+ return Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
309
+ };
310
+ const getEnabledColumnSettings = () => {
311
+ if (!props.columnManager || _Object$keys__default["default"](props.columnManager).length < 0) return undefined;
312
+ return Boolean(props.columnManager && !props.columnManager.disableColumnManager);
313
+ };
314
+ const areDisplaySettingsEnabled = getEnabledDisplaySettings();
315
+ const areColumnSettingsEnabled = getEnabledColumnSettings();
302
316
  const areCustomColumnSettingsEnabled = Boolean(props.customColumnManager && !props.customColumnManager?.disableCustomColumnManager);
303
317
  const intl = reactIntl.useIntl();
304
318
  const _useState = react.useState(null),
@@ -339,6 +353,7 @@ const DataTableSettings = props => {
339
353
  onClick: () => {
340
354
  setOpenedPanelId(option?.value);
341
355
  },
356
+ isDisabled: option?.isDisabled,
342
357
  children: option?.label
343
358
  }, option?.label))
344
359
  })
@@ -454,7 +469,7 @@ DataTableManager.displayName = 'DataTableManager';
454
469
  var DataTableManager$1 = DataTableManager;
455
470
 
456
471
  // NOTE: This string will be replaced on build time with the package version.
457
- var version = "19.12.1";
472
+ var version = "19.13.0";
458
473
 
459
474
  exports.ColumnSettingsManager = columnSettingsManager.ColumnSettingsManager;
460
475
  Object.defineProperty(exports, 'useRowSelection', {
@@ -255,7 +255,7 @@ const TopBarContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
255
255
  } : {
256
256
  name: "1ff36h2",
257
257
  styles: "flex-grow:1",
258
- 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"]} */",
258
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["data-table-settings.tsx"],"names":[],"mappings":"AAuCkC","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  isDisabled?: boolean;\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 !== undefined\n      ? [\n          {\n            value: COLUMN_MANAGER,\n            isDisabled: !areColumnSettingsEnabled,\n            label: columnManagerLabel\n              ? columnManagerLabel\n              : formatMessage(messages.columnManagerOption),\n          },\n        ]\n      : []),\n    ...(customSettings && areCustomColumnSettingsEnabled !== undefined\n      ? Object.entries(customSettings).map(([key, customSetting]) => {\n          return customSetting.type === COLUMN_MANAGER &&\n            Object.keys(customSetting).length > 0 &&\n            !areCustomColumnSettingsEnabled\n            ? {\n                value: key,\n                label: customSetting.customPanelTitle,\n                isDisabled: true,\n              }\n            : {\n                value: key,\n                label: customSetting.customPanelTitle,\n              };\n        })\n      : []),\n    ...(areDisplaySettingsEnabled !== undefined\n      ? [\n          {\n            value: DISPLAY_SETTINGS,\n            isDisabled: !areDisplaySettingsEnabled,\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 getEnabledDisplaySettings = () => {\n    if (!props.displaySettings || Object.keys(props.displaySettings).length < 0)\n      return undefined;\n\n    return Boolean(\n      props.displaySettings && !props.displaySettings.disableDisplaySettings\n    );\n  };\n  const getEnabledColumnSettings = () => {\n    if (!props.columnManager || Object.keys(props.columnManager).length < 0)\n      return undefined;\n\n    return Boolean(\n      props.columnManager && !props.columnManager.disableColumnManager\n    );\n  };\n  const areDisplaySettingsEnabled = getEnabledDisplaySettings();\n  const areColumnSettingsEnabled = getEnabledColumnSettings();\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                  isDisabled={option?.isDisabled}\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"]} */",
259
259
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
260
260
  });
261
261
  const getDropdownOptions = _ref => {
@@ -267,19 +267,25 @@ const getDropdownOptions = _ref => {
267
267
  columnManagerLabel = _ref.columnManagerLabel,
268
268
  displaySettingsLabel = _ref.displaySettingsLabel,
269
269
  formatMessage = _ref.formatMessage;
270
- return _filterInstanceProperty(_context = [...(areColumnSettingsEnabled ? [{
270
+ return _filterInstanceProperty(_context = [...(areColumnSettingsEnabled !== undefined ? [{
271
271
  value: COLUMN_MANAGER,
272
+ isDisabled: !areColumnSettingsEnabled,
272
273
  label: columnManagerLabel ? columnManagerLabel : formatMessage(messages.columnManagerOption)
273
- }] : []), ...(customSettings ? _mapInstanceProperty(_context2 = _Object$entries(customSettings)).call(_context2, _ref2 => {
274
+ }] : []), ...(customSettings && areCustomColumnSettingsEnabled !== undefined ? _mapInstanceProperty(_context2 = _Object$entries(customSettings)).call(_context2, _ref2 => {
274
275
  let _ref3 = _slicedToArray(_ref2, 2),
275
276
  key = _ref3[0],
276
277
  customSetting = _ref3[1];
277
- return customSetting.type === COLUMN_MANAGER && !areCustomColumnSettingsEnabled ? undefined : {
278
+ return customSetting.type === COLUMN_MANAGER && _Object$keys(customSetting).length > 0 && !areCustomColumnSettingsEnabled ? {
279
+ value: key,
280
+ label: customSetting.customPanelTitle,
281
+ isDisabled: true
282
+ } : {
278
283
  value: key,
279
284
  label: customSetting.customPanelTitle
280
285
  };
281
- }) : []), ...(areDisplaySettingsEnabled ? [{
286
+ }) : []), ...(areDisplaySettingsEnabled !== undefined ? [{
282
287
  value: DISPLAY_SETTINGS,
288
+ isDisabled: !areDisplaySettingsEnabled,
283
289
  label: displaySettingsLabel ? displaySettingsLabel : formatMessage(messages.displaySettingsOption)
284
290
  }] : [])]).call(_context, option => option !== undefined);
285
291
  };
@@ -295,8 +301,16 @@ const getSelectedColumns = function (mappedColumns) {
295
301
  };
296
302
  const DataTableSettings = props => {
297
303
  var _context3;
298
- const areDisplaySettingsEnabled = Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
299
- const areColumnSettingsEnabled = Boolean(props.columnManager && !props.columnManager.disableColumnManager);
304
+ const getEnabledDisplaySettings = () => {
305
+ if (!props.displaySettings || _Object$keys(props.displaySettings).length < 0) return undefined;
306
+ return Boolean(props.displaySettings && !props.displaySettings.disableDisplaySettings);
307
+ };
308
+ const getEnabledColumnSettings = () => {
309
+ if (!props.columnManager || _Object$keys(props.columnManager).length < 0) return undefined;
310
+ return Boolean(props.columnManager && !props.columnManager.disableColumnManager);
311
+ };
312
+ const areDisplaySettingsEnabled = getEnabledDisplaySettings();
313
+ const areColumnSettingsEnabled = getEnabledColumnSettings();
300
314
  const areCustomColumnSettingsEnabled = Boolean(props.customColumnManager && !props.customColumnManager?.disableCustomColumnManager);
301
315
  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;
302
316
  const intl = useIntl();
@@ -338,6 +352,7 @@ const DataTableSettings = props => {
338
352
  onClick: () => {
339
353
  setOpenedPanelId(option?.value);
340
354
  },
355
+ isDisabled: option?.isDisabled,
341
356
  children: option?.label
342
357
  }, option?.label))
343
358
  })
@@ -453,6 +468,6 @@ DataTableManager.displayName = 'DataTableManager';
453
468
  var DataTableManager$1 = DataTableManager;
454
469
 
455
470
  // NOTE: This string will be replaced on build time with the package version.
456
- var version = "19.12.1";
471
+ var version = "19.13.0";
457
472
 
458
473
  export { UPDATE_ACTIONS, DataTableManager$1 as default, version };
@@ -193,6 +193,10 @@ export type TColumnProps<Row extends TRow = TRow> = {
193
193
  shouldIgnoreRowClick?: boolean;
194
194
  };
195
195
  export type TDataTableManagerProps<Row extends TRow = TRow> = {
196
+ /**
197
+ * Set this to `true` to enable the row selection feature.
198
+ */
199
+ withRowSelection?: boolean;
196
200
  /**
197
201
  * Each object requires a unique `key` which should correspond to property key of
198
202
  * the items of `rows` that you want to render under this column, and a `label`
@@ -200,7 +204,7 @@ export type TDataTableManagerProps<Row extends TRow = TRow> = {
200
204
  * The list of columns to be rendered.
201
205
  * Each column can be customized (see properties below).
202
206
  */
203
- columns: TColumnProps<Row>[];
207
+ columns?: TColumnProps<Row>[];
204
208
  /**
205
209
  * Any React node. Usually you want to render the `<DataTable>` component.
206
210
  * <br>
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/data-table-manager",
3
3
  "description": "This component enhances the DataTable component and additionally provides a UI and state management to handle configuration of the table such as column manager.",
4
- "version": "19.12.1",
4
+ "version": "19.13.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -28,28 +28,28 @@
28
28
  "dependencies": {
29
29
  "@babel/runtime": "^7.20.13",
30
30
  "@babel/runtime-corejs3": "^7.20.13",
31
- "@commercetools-uikit/accessible-button": "19.12.1",
32
- "@commercetools-uikit/accessible-hidden": "19.12.1",
33
- "@commercetools-uikit/async-select-input": "19.12.1",
34
- "@commercetools-uikit/card": "19.12.1",
35
- "@commercetools-uikit/collapsible-motion": "19.12.1",
36
- "@commercetools-uikit/design-system": "19.12.1",
37
- "@commercetools-uikit/dropdown-menu": "19.12.1",
38
- "@commercetools-uikit/field-label": "19.12.1",
39
- "@commercetools-uikit/grid": "19.12.1",
40
- "@commercetools-uikit/hooks": "19.12.1",
41
- "@commercetools-uikit/icon-button": "19.12.1",
42
- "@commercetools-uikit/icons": "19.12.1",
43
- "@commercetools-uikit/primary-button": "19.12.1",
44
- "@commercetools-uikit/radio-input": "19.12.1",
45
- "@commercetools-uikit/secondary-button": "19.12.1",
46
- "@commercetools-uikit/secondary-icon-button": "19.12.1",
47
- "@commercetools-uikit/select-input": "19.12.1",
48
- "@commercetools-uikit/spacings": "19.12.1",
49
- "@commercetools-uikit/tag": "19.12.1",
50
- "@commercetools-uikit/text": "19.12.1",
51
- "@commercetools-uikit/tooltip": "19.12.1",
52
- "@commercetools-uikit/utils": "19.12.1",
31
+ "@commercetools-uikit/accessible-button": "19.13.0",
32
+ "@commercetools-uikit/accessible-hidden": "19.13.0",
33
+ "@commercetools-uikit/async-select-input": "19.13.0",
34
+ "@commercetools-uikit/card": "19.13.0",
35
+ "@commercetools-uikit/collapsible-motion": "19.13.0",
36
+ "@commercetools-uikit/design-system": "19.13.0",
37
+ "@commercetools-uikit/dropdown-menu": "19.13.0",
38
+ "@commercetools-uikit/field-label": "19.13.0",
39
+ "@commercetools-uikit/grid": "19.13.0",
40
+ "@commercetools-uikit/hooks": "19.13.0",
41
+ "@commercetools-uikit/icon-button": "19.13.0",
42
+ "@commercetools-uikit/icons": "19.13.0",
43
+ "@commercetools-uikit/primary-button": "19.13.0",
44
+ "@commercetools-uikit/radio-input": "19.13.0",
45
+ "@commercetools-uikit/secondary-button": "19.13.0",
46
+ "@commercetools-uikit/secondary-icon-button": "19.13.0",
47
+ "@commercetools-uikit/select-input": "19.13.0",
48
+ "@commercetools-uikit/spacings": "19.13.0",
49
+ "@commercetools-uikit/tag": "19.13.0",
50
+ "@commercetools-uikit/text": "19.13.0",
51
+ "@commercetools-uikit/tooltip": "19.13.0",
52
+ "@commercetools-uikit/utils": "19.13.0",
53
53
  "@emotion/react": "^11.10.5",
54
54
  "@emotion/styled": "^11.10.5",
55
55
  "@types/debounce-promise": "^3.1.6",