Skip to content

Commit

Permalink
Removed .defaultProps support
Browse files Browse the repository at this point in the history
  • Loading branch information
Andarist committed Dec 9, 2024
1 parent 9718d8c commit ed0d7f1
Show file tree
Hide file tree
Showing 10 changed files with 17 additions and 120 deletions.
6 changes: 6 additions & 0 deletions .changeset/early-badgers-teach.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@emotion/styled': major
'@emotion/react': major
---

Removed `.defaultProps` support
10 changes: 2 additions & 8 deletions packages/jest/test/react-enzyme.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -241,16 +241,10 @@ const cases = {
theming: {
render() {
const Button = styled.button`
color: ${props => props.theme.main};
border: 2px solid ${props => props.theme.main};
color: ${props => props.theme.main ?? 'red'};
border: 2px solid ${props => props.theme.main ?? 'red'};
`

Button.defaultProps = {
theme: {
main: 'red'
}
}

const theme = {
main: 'blue'
}
Expand Down
4 changes: 2 additions & 2 deletions packages/react/src/theming.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as React from 'react'
import weakMemoize from '@emotion/weak-memoize'
import isDevelopment from '#is-development'
import hoistNonReactStatics from './_isolated-hnrs'
import { DistributiveOmit, PropsOf } from './types'
import { DistributiveOmit } from './types'

// tslint:disable-next-line: no-empty-interface
export interface Theme {}
Expand Down Expand Up @@ -86,7 +86,7 @@ export function withTheme<
>(
Component: C
): React.ForwardRefExoticComponent<
DistributiveOmit<PropsOf<C>, 'theme'> & { theme?: Theme }
DistributiveOmit<React.ComponentProps<C>, 'theme'> & { theme?: Theme }
>
export function withTheme(
Component: React.ComponentType<any>
Expand Down
10 changes: 0 additions & 10 deletions packages/react/src/types.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,3 @@
import { ReactJSX } from './jsx-namespace'

/**
* @desc Utility type for getting props type of React component.
* It takes `defaultProps` into an account - making props with defaults optional.
*/
export type PropsOf<
C extends keyof ReactJSX.IntrinsicElements | React.JSXElementConstructor<any>
> = ReactJSX.LibraryManagedAttributes<C, React.ComponentProps<C>>

// We need to use this version of Omit as it's distributive (Will preserve unions)
export type DistributiveOmit<T, U> = T extends any
? Pick<T, Exclude<keyof T, U>>
Expand Down
17 changes: 0 additions & 17 deletions packages/react/types/tests-theming.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,27 +38,10 @@ const ThemedComp = withTheme(CompC)
;<ThemedComp prop />
;<ThemedComp prop theme={theme} />

const CompFCWithDefault = ({ prop }: Props) => (prop ? <span /> : <div />)
CompFCWithDefault.defaultProps = { prop: false }
class CompCWithDefault extends React.Component<Props> {
static defaultProps = { prop: false }
render() {
return this.props.prop ? <span /> : <div />
}
}

{
const theme: Theme = useTheme()
}

const ThemedFCWithDefault = withTheme(CompFCWithDefault)
;<ThemedFCWithDefault />
;<ThemedFCWithDefault theme={theme} />

const ThemedCompWithDefault = withTheme(CompCWithDefault)
;<ThemedCompWithDefault />
;<ThemedCompWithDefault theme={theme} />

{
interface Book {
kind: 'book'
Expand Down
1 change: 0 additions & 1 deletion packages/styled/src/base.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,6 @@ const createStyled = (tag: ElementType, options?: StyledOptions) => {
: baseTag.displayName || baseTag.name || 'Component'
})`

Styled.defaultProps = tag.defaultProps
Styled.__emotion_real = Styled
Styled.__emotion_base = baseTag
Styled.__emotion_styles = styles
Expand Down
13 changes: 6 additions & 7 deletions packages/styled/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,13 @@ export interface StyledComponent<
withComponent<C extends React.ComponentClass<React.ComponentProps<C>>>(
component: C
): StyledComponent<
ComponentProps & PropsOf<C>,
ComponentProps & React.ComponentProps<C>,
{},
{ ref?: React.Ref<InstanceType<C>> }
>
withComponent<C extends React.ComponentType<React.ComponentProps<C>>>(
component: C
): StyledComponent<ComponentProps & PropsOf<C>>
): StyledComponent<ComponentProps & React.ComponentProps<C>>
withComponent<Tag extends keyof ReactJSXIntrinsicElements>(
tag: Tag
): StyledComponent<ComponentProps, ReactJSXIntrinsicElements[Tag]>
Expand Down Expand Up @@ -113,7 +113,7 @@ export interface CreateStyled {
component: C,
options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps>
): CreateStyledComponent<
Pick<PropsOf<C>, ForwardedProps> & {
Pick<React.ComponentProps<C>, ForwardedProps> & {
theme?: Theme
},
{},
Expand All @@ -126,7 +126,7 @@ export interface CreateStyled {
component: C,
options?: StyledOptions<React.ComponentProps<C>>
): CreateStyledComponent<
PropsOf<C> & {
React.ComponentProps<C> & {
theme?: Theme
},
{},
Expand All @@ -143,7 +143,7 @@ export interface CreateStyled {
component: C,
options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps>
): CreateStyledComponent<
Pick<PropsOf<C>, ForwardedProps> & {
Pick<React.ComponentProps<C>, ForwardedProps> & {
theme?: Theme
}
>
Expand All @@ -152,7 +152,7 @@ export interface CreateStyled {
component: C,
options?: StyledOptions<React.ComponentProps<C>>
): CreateStyledComponent<
PropsOf<C> & {
React.ComponentProps<C> & {
theme?: Theme
}
>
Expand Down Expand Up @@ -182,7 +182,6 @@ export interface CreateStyled {
}

export type ElementType = React.ElementType & {
defaultProps?: Partial<any>
__emotion_real?: ElementType
__emotion_base?: ElementType
__emotion_styles?: Interpolation<Theme>[]
Expand Down
26 changes: 1 addition & 25 deletions packages/styled/test/__snapshots__/index.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ exports[`styled nested 1`] = `
<div
className="emotion-0 emotion-1"
>
hello
hello
<h1
className="emotion-2 emotion-3"
>
Expand Down Expand Up @@ -313,30 +313,6 @@ exports[`styled ref 1`] = `
</h1>
`;

exports[`styled should forward .defaultProps when reusing __emotion_base 1`] = `
.emotion-0 {
text-align: center;
color: red;
}
.emotion-2 {
text-align: center;
color: red;
font-style: italic;
}
<div>
<h1
className="emotion-0 emotion-1"
color="red"
/>
<h1
className="emotion-2 emotion-3"
color="red"
/>
</div>
`;

exports[`styled throws if undefined is passed as the component 1`] = `
"You are trying to create a styled element with an undefined component.
You may have forgotten to import it."
Expand Down
26 changes: 0 additions & 26 deletions packages/styled/test/index.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -326,32 +326,6 @@ describe('styled', () => {
expect(tree).toMatchSnapshot()
})

test('should forward .defaultProps when reusing __emotion_base', () => {
const Title = styled('h1')`
text-align: center;
${props => ({
color: props.color
})};
`

Title.defaultProps = {
color: 'red'
}

const Title2 = styled(Title)`
font-style: italic;
`

const tree = renderer
.create(
<div>
<Title />
<Title2 />
</div>
)
.toJSON()
expect(tree).toMatchSnapshot()
})
test('withComponent will replace tags but keep styling classes', () => {
const Title = styled('h1')`
color: green;
Expand Down
24 changes: 0 additions & 24 deletions packages/styled/types/tests-base.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -328,30 +328,6 @@ declare const ref3_2: (element: HTMLDivElement | null) => void
;<StyledReadable kind="magazine" author="Hejlsberg" /> // $ExpectError
}

interface Props {
prop: boolean
}
class ClassWithDefaultProps extends React.Component<Props> {
static defaultProps = { prop: false }
render() {
return this.props.prop ? <Button0 /> : <Button1 />
}
}
const StyledClassWithDefaultProps = styled(ClassWithDefaultProps)`
background-color: red;
`
const classInstance = <StyledClassWithDefaultProps />

const FCWithDefaultProps = ({ prop }: Props) =>
prop ? <Button0 /> : <Button1 />
FCWithDefaultProps.defaultProps = {
prop: false
}
const StyledFCWithDefaultProps = styled(FCWithDefaultProps)`
background-color: red;
`
const fcInstance = <StyledFCWithDefaultProps />

interface PropsA {
title: string
}
Expand Down

0 comments on commit ed0d7f1

Please sign in to comment.