@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 +26 -1
- package/dist/commercetools-uikit-data-table-manager.cjs.dev.js +23 -8
- package/dist/commercetools-uikit-data-table-manager.cjs.prod.js +22 -7
- package/dist/commercetools-uikit-data-table-manager.esm.js +23 -8
- package/dist/declarations/src/types.d.ts +5 -1
- package/package.json +23 -23
package/README.md
CHANGED
|
@@ -68,7 +68,7 @@ export default Example;
|
|
|
68
68
|
|
|
69
69
|
### Detached
|
|
70
70
|
|
|
71
|
-
As mentioned earlier, the default
|
|
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 ?
|
|
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
|
|
326
|
-
|
|
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.
|
|
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 ?
|
|
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
|
|
301
|
-
|
|
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.
|
|
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 ?
|
|
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
|
|
299
|
-
|
|
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.
|
|
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
|
|
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.
|
|
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.
|
|
32
|
-
"@commercetools-uikit/accessible-hidden": "19.
|
|
33
|
-
"@commercetools-uikit/async-select-input": "19.
|
|
34
|
-
"@commercetools-uikit/card": "19.
|
|
35
|
-
"@commercetools-uikit/collapsible-motion": "19.
|
|
36
|
-
"@commercetools-uikit/design-system": "19.
|
|
37
|
-
"@commercetools-uikit/dropdown-menu": "19.
|
|
38
|
-
"@commercetools-uikit/field-label": "19.
|
|
39
|
-
"@commercetools-uikit/grid": "19.
|
|
40
|
-
"@commercetools-uikit/hooks": "19.
|
|
41
|
-
"@commercetools-uikit/icon-button": "19.
|
|
42
|
-
"@commercetools-uikit/icons": "19.
|
|
43
|
-
"@commercetools-uikit/primary-button": "19.
|
|
44
|
-
"@commercetools-uikit/radio-input": "19.
|
|
45
|
-
"@commercetools-uikit/secondary-button": "19.
|
|
46
|
-
"@commercetools-uikit/secondary-icon-button": "19.
|
|
47
|
-
"@commercetools-uikit/select-input": "19.
|
|
48
|
-
"@commercetools-uikit/spacings": "19.
|
|
49
|
-
"@commercetools-uikit/tag": "19.
|
|
50
|
-
"@commercetools-uikit/text": "19.
|
|
51
|
-
"@commercetools-uikit/tooltip": "19.
|
|
52
|
-
"@commercetools-uikit/utils": "19.
|
|
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",
|