UNPKG

@mui/x-data-grid-premium

Version:

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

70 lines (69 loc) 2.58 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.Sidebar = Sidebar; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose")); var React = _interopRequireWildcard(require("react")); var _clsx = _interopRequireDefault(require("clsx")); var _styles = require("@mui/material/styles"); var _xDataGridPro = require("@mui/x-data-grid-pro"); var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses")); var _useGridApiContext = require("../../hooks/utils/useGridApiContext"); var _resizablePanel = require("../resizablePanel"); var _useGridRootProps = require("../../hooks/utils/useGridRootProps"); var _sidebar = require("../../hooks/features/sidebar"); var _jsxRuntime = require("react/jsx-runtime"); const _excluded = ["className", "children"]; const useUtilityClasses = ownerState => { const { classes } = ownerState; const slots = { root: ['sidebar'] }; return (0, _composeClasses.default)(slots, _xDataGridPro.getDataGridUtilityClass, classes); }; const SidebarRoot = (0, _styles.styled)(_resizablePanel.ResizablePanel, { name: 'MuiDataGrid', slot: 'Sidebar' })({ display: 'flex', flexDirection: 'column', width: 300, minWidth: 260, maxWidth: 400, overflow: 'hidden' }); function Sidebar(props) { const { className } = props, other = (0, _objectWithoutPropertiesLoose2.default)(props, _excluded); const apiRef = (0, _useGridApiContext.useGridApiContext)(); const rootProps = (0, _useGridRootProps.useGridRootProps)(); const classes = useUtilityClasses(rootProps); const { value, sidebarId, labelId } = (0, _xDataGridPro.useGridSelector)(apiRef, _sidebar.gridSidebarContentSelector); if (!value) { return null; } const sidebarContent = apiRef.current.unstable_applyPipeProcessors('sidebar', null, value); if (!sidebarContent) { return null; } return /*#__PURE__*/(0, _jsxRuntime.jsxs)(SidebarRoot, (0, _extends2.default)({ id: sidebarId, className: (0, _clsx.default)(className, classes.root), ownerState: rootProps, "aria-labelledby": labelId }, other, { children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_resizablePanel.ResizablePanelHandle, {}), sidebarContent] })); }