import * as React from 'react'; import { OverridableComponent, OverrideProps } from '@mui/types'; import { Theme as SystemTheme } from "../createTheme/index.js"; import { SxProps, AllSystemCSSProperties, ResponsiveStyleValue, OverwriteCSSProperties, AliasesCSSProperties } from "../styleFunctionSx/index.js"; import { PropsFor } from "../style/index.js"; import { ComposedStyleFunction } from "../compose/index.js"; import borders from "../borders/index.js"; import display from "../display/index.js"; import flexbox from "../flexbox/index.js"; import grid from "../cssGrid/index.js"; import palette from "../palette/index.js"; import positions from "../positions/index.js"; import shadows from "../shadows/index.js"; import sizing from "../sizing/index.js"; import spacing from "../spacing/index.js"; import typography from "../typography/index.js"; export interface CustomSystemProps extends AliasesCSSProperties, OverwriteCSSProperties {} export type SimpleSystemKeys = keyof PropsFor>; // The SimpleSystemKeys are subset of the AllSystemCSSProperties, so this should be ok // This is needed as these are used as keys inside AllSystemCSSProperties type StandardSystemKeys = Extract; export type SystemProps = { [K in StandardSystemKeys]?: ResponsiveStyleValue | ((theme: Theme) => ResponsiveStyleValue) }; export interface BoxOwnProps extends SystemProps { children?: React.ReactNode; ref?: React.Ref; /** * The system prop that allows defining system overrides as well as additional CSS styles. */ sx?: SxProps; } export interface BoxTypeMap { props: AdditionalProps & BoxOwnProps; defaultComponent: RootComponent; } /** * * Demos: * * - [Box (Joy UI)](https://mui.com/joy-ui/react-box/) * - [Box (Material UI)](https://mui.com/material-ui/react-box/) * - [Box (MUI System)](https://mui.com/system/react-box/) * * API: * * - [Box API](https://mui.com/system/api/box/) */ declare const Box: OverridableComponent; export type BoxProps = OverrideProps, RootComponent> & { component?: React.ElementType; }; export default Box;