import { SystemStyleObject, StyleProps } from '@chakra-ui/styled-system'; import { Dict } from '@chakra-ui/utils'; import { CSSObject, FunctionInterpolation } from '@emotion/styled'; import { As, ChakraComponent, PropsOf, ChakraProps } from './system.types.mjs'; import { DOMElements } from './system.utils.mjs'; import '@emotion/react'; type StyleResolverProps = SystemStyleObject & { __css?: SystemStyleObject; sx?: SystemStyleObject; theme: any; css?: CSSObject; }; interface GetStyleObject { (options: { baseStyle?: SystemStyleObject | ((props: StyleResolverProps) => SystemStyleObject); }): FunctionInterpolation; } /** * Style resolver function that manages how style props are merged * in combination with other possible ways of defining styles. * * For example, take a component defined this way: * ```jsx * * ``` * * We want to manage the priority of the styles properly to prevent unwanted * behaviors. Right now, the `sx` prop has the highest priority so the resolved * fontSize will be `40px` */ declare const toCSSObject: GetStyleObject; interface ChakraStyledOptions extends Dict { shouldForwardProp?(prop: string): boolean; label?: string; baseStyle?: SystemStyleObject | ((props: StyleResolverProps) => SystemStyleObject); } declare function styled(component: T, options?: ChakraStyledOptions): ChakraComponent; type HTMLChakraComponents = { [Tag in DOMElements]: ChakraComponent; }; type HTMLChakraProps = Omit, "ref" | keyof StyleProps> & ChakraProps & { as?: As; }; export { ChakraStyledOptions, HTMLChakraComponents, HTMLChakraProps, styled, toCSSObject };