Skip to content

Commit

Permalink
Fixed an issue with React giving warning about static children not ha…
Browse files Browse the repository at this point in the history
…ving unique keys when using classic `jsx` factory (#2066)
  • Loading branch information
Andarist authored Nov 2, 2020
1 parent 0abe324 commit fe30cbd
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 12 deletions.
12 changes: 12 additions & 0 deletions .changeset/dull-ghosts-help.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
---
'@emotion/core': patch
---

Fixed an issue with React giving warning about static children not having unique keys when using the classic `jsx` factory. This example illustrates the situation in which this has been incorrectly happening:

```js
<div css={{ color: 'hotpink' }}>
<div />
<div />
</div>
```
10 changes: 10 additions & 0 deletions packages/core/__tests__/warnings.js
Original file line number Diff line number Diff line change
Expand Up @@ -261,3 +261,13 @@ test('`css` opaque object passed in as `className` prop', () => {
</div>
`)
})

test('when using `jsx` multiple static children should not result in a key-related warning', () => {
renderer.create(
<div css={{ color: 'hotpink' }}>
<div />
<div />
</div>
)
expect((console.error: any).mock.calls).toMatchInlineSnapshot(`Array []`)
})
19 changes: 7 additions & 12 deletions packages/core/src/jsx.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,20 +15,15 @@ export const jsx: typeof React.createElement = function(
return React.createElement.apply(undefined, args)
}

const emotionProps = createEmotionProps(type, props)
let argsLength = args.length
let createElementArgArray = new Array(argsLength)
createElementArgArray[0] = Emotion
createElementArgArray[1] = createEmotionProps(type, props)

// https://github.com/facebook/react/blob/fd61f7ea53989a59bc427603798bb111c852816a/packages/react/src/ReactElement.js#L386-L400
const childrenLength = args.length - 2
if (childrenLength === 1) {
emotionProps.children = args[2]
} else if (childrenLength > 1) {
const childArray = new Array(childrenLength)
for (let i = 0; i < childrenLength; i++) {
childArray[i] = args[i + 2]
}
emotionProps.children = childArray
for (let i = 2; i < argsLength; i++) {
createElementArgArray[i] = args[i]
}

// $FlowFixMe
return React.createElement(Emotion, emotionProps)
return React.createElement.apply(null, createElementArgArray)
}

0 comments on commit fe30cbd

Please sign in to comment.