UNPKG

@mui/x-data-grid

Version:

The Community plan edition of the Data Grid components (MUI X).

53 lines (52 loc) 2.31 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.useDataGridProps = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var React = _interopRequireWildcard(require("react")); var _styles = require("@mui/material/styles"); var _constants = require("../constants"); var _defaultGridSlotsComponents = require("../constants/defaultGridSlotsComponents"); var _utils = require("../internals/utils"); var _dataGridPropsDefaultValues = require("../constants/dataGridPropsDefaultValues"); const DATA_GRID_FORCED_PROPS = { disableMultipleColumnsFiltering: true, disableMultipleColumnsSorting: true, throttleRowsMs: undefined, hideFooterRowCount: false, pagination: true, checkboxSelectionVisibleOnly: false, disableColumnReorder: true, keepColumnPositionIfDraggedOutside: false, signature: 'DataGrid', unstable_listView: false }; const defaultSlots = _defaultGridSlotsComponents.DATA_GRID_DEFAULT_SLOTS_COMPONENTS; const useDataGridProps = inProps => { const themedProps = (0, _utils.useProps)( // eslint-disable-next-line material-ui/mui-name-matches-component-name (0, _styles.useThemeProps)({ props: inProps, name: 'MuiDataGrid' })); const localeText = React.useMemo(() => (0, _extends2.default)({}, _constants.GRID_DEFAULT_LOCALE_TEXT, themedProps.localeText), [themedProps.localeText]); const slots = React.useMemo(() => (0, _utils.computeSlots)({ defaultSlots, slots: themedProps.slots }), [themedProps.slots]); const injectDefaultProps = React.useMemo(() => { return Object.keys(_dataGridPropsDefaultValues.DATA_GRID_PROPS_DEFAULT_VALUES).reduce((acc, key) => { // @ts-ignore acc[key] = themedProps[key] ?? _dataGridPropsDefaultValues.DATA_GRID_PROPS_DEFAULT_VALUES[key]; return acc; }, {}); }, [themedProps]); return React.useMemo(() => (0, _extends2.default)({}, themedProps, injectDefaultProps, { localeText, slots }, DATA_GRID_FORCED_PROPS), [themedProps, localeText, slots, injectDefaultProps]); }; exports.useDataGridProps = useDataGridProps;