@mui/x-data-grid-premium
Version:
The Premium plan edition of the MUI X Data Grid Components.
75 lines (73 loc) • 3.54 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useDataGridPremiumProps = exports.DATA_GRID_PREMIUM_PROPS_DEFAULT_VALUES = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var React = _interopRequireWildcard(require("react"));
var _styles = require("@mui/material/styles");
var _system = require("@mui/system");
var _xDataGridPro = require("@mui/x-data-grid-pro");
var _internals = require("@mui/x-data-grid-pro/internals");
var _aggregation = require("../hooks/features/aggregation");
var _dataGridPremiumDefaultSlotsComponents = require("../constants/dataGridPremiumDefaultSlotsComponents");
var _utils = require("../hooks/features/pivoting/utils");
var _gridAggregationUtils = require("../hooks/features/aggregation/gridAggregationUtils");
var _constants = require("../hooks/features/history/constants");
const getDataGridPremiumForcedProps = themedProps => (0, _extends2.default)({
signature: _xDataGridPro.GridSignature.DataGridPremium
}, themedProps.dataSource ? {
filterMode: 'server',
sortingMode: 'server',
paginationMode: 'server'
} : {});
/**
* The default values of `DataGridPremiumPropsWithDefaultValue` to inject in the props of DataGridPremium.
*/
const DATA_GRID_PREMIUM_PROPS_DEFAULT_VALUES = exports.DATA_GRID_PREMIUM_PROPS_DEFAULT_VALUES = (0, _extends2.default)({}, _xDataGridPro.DATA_GRID_PRO_PROPS_DEFAULT_VALUES, {
cellSelection: false,
disableAggregation: false,
disableRowGrouping: false,
rowGroupingColumnMode: 'single',
aggregationFunctions: _aggregation.GRID_AGGREGATION_FUNCTIONS,
aggregationRowsScope: 'filtered',
getAggregationPosition: _gridAggregationUtils.defaultGetAggregationPosition,
disableClipboardPaste: false,
splitClipboardPastedText: (pastedText, delimiter = '\t') => {
// Excel on Windows adds an empty line break at the end of the copied text.
// See https://github.com/mui/mui-x/issues/9103
const text = pastedText.replace(/\r?\n$/, '');
return text.split(/\r\n|\n|\r/).map(row => row.split(delimiter));
},
disablePivoting: false,
aiAssistant: false,
chartsIntegration: false,
historyStackSize: 30,
historyEventHandlers: {},
historyValidationEvents: _constants.DEFAULT_HISTORY_VALIDATION_EVENTS
});
const defaultSlots = _dataGridPremiumDefaultSlotsComponents.DATA_GRID_PREMIUM_DEFAULT_SLOTS_COMPONENTS;
const useDataGridPremiumProps = inProps => {
const theme = (0, _styles.useTheme)();
const themedProps = React.useMemo(() => (0, _system.getThemeProps)({
props: inProps,
theme,
name: 'MuiDataGrid'
}), [theme, inProps]);
const localeText = React.useMemo(() => (0, _extends2.default)({}, _xDataGridPro.GRID_DEFAULT_LOCALE_TEXT, themedProps.localeText), [themedProps.localeText]);
const slots = React.useMemo(() => (0, _internals.computeSlots)({
defaultSlots,
slots: themedProps.slots
}), [themedProps.slots]);
return React.useMemo(() => (0, _extends2.default)({}, DATA_GRID_PREMIUM_PROPS_DEFAULT_VALUES, themedProps.dataSource ? {
aggregationFunctions: {}
} : {
getPivotDerivedColumns: _utils.defaultGetPivotDerivedColumns
}, themedProps, {
localeText,
slots
}, getDataGridPremiumForcedProps(themedProps)), [themedProps, localeText, slots]);
};
exports.useDataGridPremiumProps = useDataGridPremiumProps;