UNPKG

@emotion/styled

Version:
194 lines (177 loc) 5.5 kB
// Definitions by: Junyoung Clare Jang <https://github.com/Ailrun> // TypeScript Version: 3.2 import * as React from 'react' import { ComponentSelector, Interpolation } from '@emotion/serialize' import { PropsOf, Theme } from '@emotion/react' export { ArrayInterpolation, CSSObject, FunctionInterpolation } from '@emotion/serialize' export { ComponentSelector, Interpolation } /** Same as StyledOptions but shouldForwardProp must be a type guard */ export interface FilteringStyledOptions< Props = Record<string, any>, ForwardedProps extends keyof Props & string = keyof Props & string > { label?: string shouldForwardProp?: (propName: string) => propName is ForwardedProps target?: string } export interface StyledOptions<Props = Record<string, any>> { label?: string shouldForwardProp?: (propName: string) => boolean target?: string } /** * @typeparam ComponentProps Props which will be included when withComponent is called * @typeparam SpecificComponentProps Props which will *not* be included when withComponent is called */ export interface StyledComponent< ComponentProps extends {}, SpecificComponentProps extends {} = {}, JSXProps extends {} = {} > extends React.FC<ComponentProps & SpecificComponentProps & JSXProps>, ComponentSelector { withComponent<C extends React.ComponentClass<React.ComponentProps<C>>>( component: C ): StyledComponent< ComponentProps & PropsOf<C>, {}, { ref?: React.Ref<InstanceType<C>> } > withComponent<C extends React.ComponentType<React.ComponentProps<C>>>( component: C ): StyledComponent<ComponentProps & PropsOf<C>> withComponent<Tag extends keyof JSX.IntrinsicElements>( tag: Tag ): StyledComponent<ComponentProps, JSX.IntrinsicElements[Tag]> } /** * @typeparam ComponentProps Props which will be included when withComponent is called * @typeparam SpecificComponentProps Props which will *not* be included when withComponent is called */ export interface CreateStyledComponent< ComponentProps extends {}, SpecificComponentProps extends {} = {}, JSXProps extends {} = {} > { /** * @typeparam AdditionalProps Additional props to add to your styled component */ <AdditionalProps extends {} = {}>( ...styles: Array< Interpolation< ComponentProps & SpecificComponentProps & AdditionalProps & { theme: Theme } > > ): StyledComponent< ComponentProps & AdditionalProps, SpecificComponentProps, JSXProps > ( template: TemplateStringsArray, ...styles: Array< Interpolation<ComponentProps & SpecificComponentProps & { theme: Theme }> > ): StyledComponent<ComponentProps, SpecificComponentProps, JSXProps> /** * @typeparam AdditionalProps Additional props to add to your styled component */ <AdditionalProps extends {}>( template: TemplateStringsArray, ...styles: Array< Interpolation< ComponentProps & SpecificComponentProps & AdditionalProps & { theme: Theme } > > ): StyledComponent< ComponentProps & AdditionalProps, SpecificComponentProps, JSXProps > } /** * @desc * This function accepts a React component or tag ('div', 'a' etc). * * @example styled(MyComponent)({ width: 100 }) * @example styled(MyComponent)(myComponentProps => ({ width: myComponentProps.width }) * @example styled('div')({ width: 100 }) * @example styled('div')<Props>(props => ({ width: props.width }) */ export interface CreateStyled { < C extends React.ComponentClass<React.ComponentProps<C>>, ForwardedProps extends keyof React.ComponentProps<C> & string = keyof React.ComponentProps<C> & string >( component: C, options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps> ): CreateStyledComponent< Pick<PropsOf<C>, ForwardedProps> & { theme?: Theme }, {}, { ref?: React.Ref<InstanceType<C>> } > <C extends React.ComponentClass<React.ComponentProps<C>>>( component: C, options?: StyledOptions<React.ComponentProps<C>> ): CreateStyledComponent< PropsOf<C> & { theme?: Theme }, {}, { ref?: React.Ref<InstanceType<C>> } > < C extends React.ComponentType<React.ComponentProps<C>>, ForwardedProps extends keyof React.ComponentProps<C> & string = keyof React.ComponentProps<C> & string >( component: C, options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps> ): CreateStyledComponent< Pick<PropsOf<C>, ForwardedProps> & { theme?: Theme } > <C extends React.ComponentType<React.ComponentProps<C>>>( component: C, options?: StyledOptions<React.ComponentProps<C>> ): CreateStyledComponent< PropsOf<C> & { theme?: Theme } > < Tag extends keyof JSX.IntrinsicElements, ForwardedProps extends keyof JSX.IntrinsicElements[Tag] & string = keyof JSX.IntrinsicElements[Tag] & string >( tag: Tag, options: FilteringStyledOptions<JSX.IntrinsicElements[Tag], ForwardedProps> ): CreateStyledComponent< { theme?: Theme; as?: React.ElementType }, Pick<JSX.IntrinsicElements[Tag], ForwardedProps> > <Tag extends keyof JSX.IntrinsicElements>( tag: Tag, options?: StyledOptions<JSX.IntrinsicElements[Tag]> ): CreateStyledComponent< { theme?: Theme; as?: React.ElementType }, JSX.IntrinsicElements[Tag] > } declare const styled: CreateStyled export default styled