UNPKG

@mui/x-data-grid-premium

Version:

The Premium plan edition of the MUI X Data Grid Components.

75 lines (73 loc) 3.54 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.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;