Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v11 #1600

Merged
merged 191 commits into from
Nov 12, 2020
Merged

v11 #1600

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
191 commits
Select commit Hold shift + click to select a range
4b313e4
Enter pre
emmatown Nov 2, 2019
b0ad4f0
Avoid transpiling vanilla emotion calls in already transpiled code to…
Andarist Nov 3, 2019
302bdba
Add a changeset
emmatown Nov 3, 2019
720eb06
Version Packages (#1603)
github-actions[bot] Nov 3, 2019
e67a5be
Jest emotion/improvements (#1604)
Andarist Nov 4, 2019
a72e6dc
Restructured types to greatly reduce number of types created during c…
Nov 4, 2019
2293547
Make StyledComponent polymorphic (#1588)
FezVrasta Nov 5, 2019
1eaa3a3
Update changes.json
emmatown Nov 5, 2019
40beaad
Version Packages (#1605)
github-actions[bot] Nov 5, 2019
70bc4ef
Add CodeSandbox CI Config (#1608)
Andarist Nov 5, 2019
7903605
Use Hooks (#967)
emmatown Nov 5, 2019
e808fd4
Version Packages (#1610)
github-actions[bot] Nov 5, 2019
8a896a3
Throw error about invalid content property values instead of just log…
Andarist Nov 6, 2019
ddf30f0
Upgrade to @preconstruct/cli
emmatown Nov 6, 2019
9f2e6ac
Revert "Upgrade to @preconstruct/cli"
emmatown Nov 6, 2019
a085003
Add missing #__PURE__ annotations (#1613)
Andarist Nov 7, 2019
794d4c1
Add babel-plugin-emotion to CodeSandbox CI config
Andarist Nov 7, 2019
c5b12d9
Add import mapping to babel plugin (#1220)
emmatown Nov 8, 2019
dfec4b6
Update release workflow
emmatown Nov 8, 2019
a91a3de
Merge branch 'master' into next
emmatown Nov 8, 2019
1ab8ec2
Update changesets
emmatown Nov 8, 2019
f9feab1
Move @emotion/styled-base to @emotion/styled/base (#1575)
emmatown Nov 8, 2019
541ebf2
Tweak styled-base deprecation error message
Andarist Nov 8, 2019
fd4b227
Upgrade Babel-related deps (#1621)
Andarist Nov 9, 2019
5fcc4dc
Version Packages (#1612)
github-actions[bot] Nov 9, 2019
22e05c6
Upgrade jest-watch-typeahead
Andarist Nov 9, 2019
fc4852c
Add preinstall script checking if yarn is being used for installation…
Andarist Nov 9, 2019
c65c5d8
Drop Babel 6 support (#1622)
Andarist Nov 11, 2019
702f3fd
Added the `T` parameter to the `Matchers` interface
spudly Nov 12, 2019
e6e079c
Fix for TypeScript error when importing `@emotion/styled/base` in com…
frankwallis Nov 13, 2019
6fd588f
Version Packages (next) (#1625)
github-actions[bot] Nov 13, 2019
99c6b7e
Fixed missing type from the interpolation intersection type (#1632)
Nov 14, 2019
ad77ed2
Create new overload for CreateStyled which supports shouldForwardProp…
JakeGinnivan Nov 14, 2019
4f5450c
Version Packages (#1633)
github-actions[bot] Nov 15, 2019
843bfb1
Add @emotion/core/macro, remove @emotion/css (#1630)
Andarist Nov 15, 2019
828111c
Handle `Global` with Babel (#1639)
Andarist Nov 17, 2019
f1b7c9d
Added basic support for accepting custom `shouldForwardProp` option i…
Andarist Nov 18, 2019
8ad4af4
Update jest-emotion installation instructions (#1645)
ajs139 Nov 18, 2019
cbb8b79
Move theming APIs to core (#1628)
Andarist Nov 18, 2019
923ded0
Relaxed types for shouldForwardProp (#1643)
JakeGinnivan Nov 19, 2019
4a891bf
Allow for pre-pending style tags to container element (#1473)
jcharry Nov 25, 2019
0a4a22f
Allow `labelFormat` option to be a function (#1651)
Andarist Nov 25, 2019
3b9cb9e
Version Packages (#1638)
github-actions[bot] Nov 25, 2019
5c55fd1
Fix to what location generated source maps are pointing in case of co…
Andarist Nov 26, 2019
729ef9d
Update csstype dep
Andarist Nov 26, 2019
0b817da
Version Packages (#1654)
github-actions[bot] Nov 26, 2019
14745a5
Fix repository link for utils package (#1658)
sindreij Nov 28, 2019
c6d2b80
Merge branch 'master' into next
Andarist Nov 28, 2019
c5e91b0
Merge branch 'master' into next
Andarist Nov 29, 2019
c672175
Added support for passing theme to functions in array css prop (#1130)
jtmthf Dec 2, 2019
0b7ebdf
Merge branch 'master' into next
Andarist Dec 4, 2019
c643107
Refactor TS types to use builtin Theme interface which can be augment…
tomsseisums Dec 7, 2019
0362fd2
Version Packages (#1663)
github-actions[bot] Dec 7, 2019
0f3a2d3
Created additional overload to prevent AdditionalProps getting inferr…
JakeGinnivan Dec 8, 2019
8b59959
Add handling of the css prop in syntax-preference rule (#1659)
Andarist Dec 8, 2019
ba105a5
Version Packages (#1679)
github-actions[bot] Dec 10, 2019
2fa7a21
Remove no longer needed StyleProps type parameter (#1685)
Andarist Dec 14, 2019
456be9a
Added TS types to @emotion/native (#1634)
patsissons Dec 16, 2019
8c519e0
Merge branch 'master' into next
emmatown Dec 19, 2019
dfe79ac
Fix issue with rehydrated style tags not taking into account prepend …
Andarist Dec 20, 2019
1e4a741
Removed mentions of `maxLength` option (#1697)
Andarist Dec 20, 2019
4a89042
Fix issue with sheet hydration in cache creation (#1699)
Andarist Dec 22, 2019
d62d910
Add warning if multiple versions are running (addresses #1470) (#1677)
ajs139 Dec 24, 2019
affed3d
Fix issue with published TypeScript test files augmenting Theme inter…
Andarist Dec 28, 2019
c7850e6
Optimize Babel output a little bit (#1656)
Andarist Jan 5, 2020
5936812
Improve support for Enzyme's shallow rendering (#1672)
ajs139 Jan 5, 2020
b8476e0
Rename packages (#1675)
emmatown Jan 5, 2020
31e610f
Version Packages (next) (#1691)
github-actions[bot] Jan 5, 2020
b79781f
Fix the type of `props.theme` for StyledComponent without AdditionalP…
fabien0102 Jan 9, 2020
cb637e6
Add types folder to published files for native (#1716)
META-DREAMER Jan 14, 2020
f08ef5a
Removed leftover `@emotion/react` import from type definition file (#…
Andarist Jan 16, 2020
d950d7d
Version Packages (next) (#1711)
github-actions[bot] Jan 16, 2020
7dea6d7
Fixed styles inserted by `<Global/>` component not inheriting `speedy…
Andarist Jan 22, 2020
4aacba5
Update jest-related deps (#1733)
Andarist Jan 22, 2020
11fc27f
Match supported components to what is exported from the latest versio…
Zn4rK Feb 27, 2020
c693d8a
Merge branch 'master' into next
Andarist Feb 27, 2020
e3d7db8
Fixed some composition issues with styles not containing a final semi…
Andarist Feb 29, 2020
c2fc3cc
Merge branch 'master' into next
Andarist Mar 2, 2020
fbf9ad2
Fix manypkg errors
Andarist Mar 2, 2020
5c63a0e
Upgrade changesets deps
Andarist Mar 2, 2020
a8c9942
Migrate v1 changesets to v2 ones
Andarist Mar 2, 2020
9e833ba
Fix UMD name for @emotion/react package
Andarist Mar 12, 2020
9e3315d
Remove unnecessary @emotion/styled import from theming declaration fi…
Andarist Mar 14, 2020
1a7c9a8
Merge branch 'master' into next
Andarist Mar 14, 2020
994402e
Bring back accidentally removed tests
Andarist Mar 14, 2020
d9829aa
Merge branch 'master' into next
Andarist Mar 14, 2020
5bea60b
Drop support for interpolating generated class names (#1807)
Andarist Mar 15, 2020
3370dd5
Improve docs around augmenting the Theme interface (#1803)
Andarist Mar 15, 2020
3e08486
Removed a test which was removed as part of #1807
Andarist Mar 15, 2020
be2eb61
Do not warn about @emotion/react being loaded twice in Jest (#1806)
Andarist Mar 16, 2020
105de5c
Fixed issue with cache created in render crashing SSRed site (#1572)
Andarist Mar 16, 2020
6e5e4eb
Change a console.warn to console.error for reporting bad rule inserti…
Andarist Mar 16, 2020
75e2f9e
Add a dev-only warning about opaque styles being passed to `cx` (#1810)
Andarist Mar 16, 2020
5c7ec85
Relax requirement for label extraction - containing functions dont ha…
Andarist Mar 16, 2020
2ae1069
Bump version of @emotion/serialize to fixup repo/npm/changesets mismatch
Andarist Mar 17, 2020
ff9746b
ci(changeset): generate PR with changelog & (next) version updates (#…
github-actions[bot] Mar 17, 2020
4ed12cb
Add TS test to check for excessive instantiation regressions
Andarist Mar 28, 2020
fc11976
Fix advanced SSR docs
Andarist May 20, 2020
5e80310
Added support for converting assignment expressions to labels (#1893)
Andarist Jun 9, 2020
91046a8
Rename sheet.rehydrate method to sheet.hydrate (#1900)
Andarist Jun 13, 2020
ec2bfbf
Fix the links fixer (#1903)
Andarist Jun 15, 2020
9e998e3
Upgrade Stylis to v4 (#1817)
Andarist Jun 22, 2020
ca599c5
Jest serializer new api (#1901)
Andarist Jun 22, 2020
9391227
Upgrade Stylis version
Andarist Jun 22, 2020
420bd67
Version Packages (next) (#1896)
github-actions[bot] Jun 22, 2020
7d475c3
Update testing reference. (#1445)
jonearley Jun 27, 2020
25ea45f
Remove invalid argument in favor of using @emotion/css over @emotion/…
pcowgill Jun 28, 2020
cd77efb
Cleanup @emotion/jest entrypoints (#1920)
Andarist Jul 2, 2020
97d1f97
Warn about incompatibility with @babel/plugin-transform-react-inline-…
slapbox Jul 2, 2020
5ad3e44
Mention in the docs that `theme` prop is not forwarded to custom comp…
blicksky Jul 2, 2020
d484252
Bump Stylis version
Andarist Jul 5, 2020
c7ae475
Change which interface gets extended with css prop support (#1762)
Andarist Jul 5, 2020
a19acbd
Upgrade Flow to 0.128.0 (#1925)
Andarist Jul 5, 2020
62d579e
Merge branch 'master' into next
Andarist Jul 5, 2020
ab09e9e
Fix outdated reference to @emotion/core (#1926)
Andarist Jul 6, 2020
58dc08a
Adds @types/react as optional peer deps (#1837)
arcanis Jul 7, 2020
6d32d82
Add speedy method to the TS type declaration of the sheet object avai…
osdiab Jul 8, 2020
4d3b60d
Added basic TS type support for `as` prop on styled components (#1874)
connor-baer Jul 9, 2020
1e10d8c
Remove not needed files in jest package extra entrypoints
Andarist Jul 12, 2020
f57a722
Localized jsx namespace (#1941)
Andarist Jul 30, 2020
4c2601e
Fix v11 jsx factory type not allowing children when implictly in comp…
emmatown Aug 1, 2020
d083a76
Minor TS types tweak in @emotion/styled (#1951)
Andarist Aug 1, 2020
93c27e0
Version Packages (next) (#1923)
github-actions[bot] Aug 1, 2020
dc1a0c5
Insert empty style elements eagerly in dev (#1962)
Andarist Aug 7, 2020
9072e78
Small docs tweaks after changes related to Stylis v4 work (#1949)
Andarist Aug 7, 2020
e07873b
Upgrade changesets, manypkg & preconstruct deps
Andarist Aug 8, 2020
8a88e77
Improved reliability of snapshots by having consistent order of extra…
Jimmydalecleveland Aug 9, 2020
ae8c1d9
Fixed `@emotion/jest` toHaveStyleRule on react.elements (#1902)
Andarist Aug 9, 2020
ce3ae19
Merge branch 'master' into next
Andarist Aug 9, 2020
5d692a6
Upgrade csstype dependency (#1956)
eps1lon Aug 9, 2020
620f732
Add TS types support for `ref` on class components (including host co…
Andarist Aug 9, 2020
62fc844
Add Pressable to the list of supported react-native components (#1958)
sanpoChew Aug 9, 2020
aeb15ef
Merge branch 'master' into next
Andarist Aug 18, 2020
aa5f6c9
Fix changeset header, target `@emotion/react` instead of `@emotion/core`
Andarist Aug 18, 2020
908a264
Version Packages (next) (#1963)
github-actions[bot] Aug 18, 2020
c510d9d
Change some changeset bump types and do a few changeset cleanups (#1980)
Andarist Aug 21, 2020
58b2bbc
Change the key of a global key (indicating the @emotion/react has bee…
Andarist Aug 21, 2020
24e5109
Add Browser Requirements section to the docs (#1979)
Andarist Aug 21, 2020
8db5c32
Document caveat with css prop and React.cloneElement (#1985)
Andarist Sep 3, 2020
18c0d5f
Custom `shouldForwardProp` is being preserved now when using `.withCo…
animecyc Sep 4, 2020
0895f1f
Fixed an issue with type for as prop not being available for prebound…
Andarist Sep 5, 2020
debaad9
Fixed TypeScript definition of the `EmotionCache` by replacing the no…
RoystonS Sep 6, 2020
39be057
Insert empty rule in dev (#1997)
Andarist Sep 8, 2020
a8eb4e7
Styles are now correctly extracted from the correct cache (`key`-sens…
Andarist Sep 8, 2020
dfe9802
Fixed an issue with orphaned pseudos having their selector doubled fo…
Andarist Sep 8, 2020
23faf9e
Fixed an issue with wrapped class components not having a type for th…
Andarist Sep 8, 2020
8307133
Version Packages (next) (#1982)
github-actions[bot] Sep 8, 2020
691aedb
Upgrade Changesets, Manypkg & Preconstruct
Andarist Sep 9, 2020
76e3dc4
Trigger re-release of @emotion/serialize package (#2009)
Andarist Sep 9, 2020
1ee8b44
Version Packages (next) (#2010)
github-actions[bot] Sep 9, 2020
db16ac3
Fixed an issue with internal buffer being lost for nested factory cal…
Andarist Sep 15, 2020
19df60b
Fixed an issue with rules nested in orphaned pseudo selectors not bei…
Andarist Sep 15, 2020
d949a37
Upgrade stylis dependency ranges
Andarist Sep 15, 2020
95ea283
Disallow functions as value of style prop in libs related to React Na…
Andarist Sep 20, 2020
0c4c051
Version Packages (next) (#2018)
github-actions[bot] Sep 20, 2020
d55556e
Partial changesets cleanup (#2016)
Andarist Sep 21, 2020
5d094b5
Fixed an issue with serializing Enzyme's `ReactWrapper` (what is retu…
Andarist Oct 1, 2020
42df3f3
Fixed an issue with multiple Emotion caches moving SSRed styles to he…
Andarist Oct 3, 2020
3b460da
Version Packages (next) (#2029)
github-actions[bot] Oct 3, 2020
6ad4cb0
Cleanup some changesets that were only relevant during premode
Andarist Oct 3, 2020
9c4ebc1
Prepare first RC release (#2030)
Andarist Oct 3, 2020
a775ddc
Upgrade testing related deps (#2033)
Andarist Oct 3, 2020
a425902
Use caret dependency ranges when possible (#2032)
Andarist Oct 10, 2020
69446cb
Adds translate to the list of the valid props (#1971)
mjcampagna Oct 11, 2020
58e8c11
Allow ESLint 7 as peer dep of @emotion/eslint-plugin (#2034)
Andarist Oct 11, 2020
ff4ee9d
Version Packages (rc) (#2031)
github-actions[bot] Oct 11, 2020
3b29839
Upgrade Preconstruct
Andarist Oct 18, 2020
5a73355
Downgrade Preconstruct to 1.1.29
Andarist Oct 18, 2020
3abcf67
`@types/jest` has been moved from the dependencies to the optional pe…
Andarist Oct 18, 2020
6e157aa
Remove missing key error from production environments (#2042)
Andarist Oct 18, 2020
082e970
Remove patch for @changesets/cli
Andarist Nov 7, 2020
f02507c
Upgrade chalk and escape-string-regexp (#2044)
TrySound Nov 7, 2020
2d59785
Add support for the `as` prop in React Native related packages (#2058)
efoken Nov 7, 2020
d627db4
Merge branch 'master' into next
Andarist Nov 8, 2020
0d34200
Fix flow error
Andarist Nov 9, 2020
30ddee1
Merge branch 'master' into next
Andarist Nov 9, 2020
9e3671c
Remove the `runtime` option from `@emotion/babel-preset-css-prop` (#2…
Andarist Nov 9, 2020
74ec012
Export JSX namespace from automatic runtime entries (#2078)
Andarist Nov 9, 2020
688586d
Fixed an issue with dev-only labels not being added when source maps …
Andarist Nov 9, 2020
b7d2137
Make `cssPropOptimization`'s default always `true` (regardless of the…
Andarist Nov 9, 2020
db32e5a
Merge branch 'master' into next
Andarist Nov 10, 2020
cf56694
Preconstruct upgrade (#2088)
Andarist Nov 10, 2020
a293f90
Add changeset about UMD filenames being renamed
Andarist Nov 10, 2020
3c3bc41
Exit pre mode
Andarist Nov 10, 2020
20d2249
Remove unnecessary changeset
Andarist Nov 10, 2020
139ea33
Use `StyleSheet.create` in React Native (#2060)
efoken Nov 11, 2020
27b2357
Fixed `@emotion/server/create-instance` entrypoint configuration
Andarist Nov 11, 2020
e6e209c
Remove unnecessary changesets and fixup old changelogs entries
Andarist Nov 11, 2020
5b7f4b5
Update README.md
emmatown Nov 11, 2020
4e1c94c
Emotion 11 post (#2089)
Andarist Nov 12, 2020
b99c44c
Version Packages (#2046)
github-actions[bot] Nov 12, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Use StyleSheet.create in React Native (#2060)
* Use `StyleSheet.create` in React Native

* Flatten the styles before passing them to `StyleSheet.create`

* Fix primitives tests

* Update snapshots

* Fix flow errors

* Add changeset

Co-authored-by: Mateusz Burzyński <mateuszburzynski@gmail.com>
  • Loading branch information
efoken and Andarist authored Nov 11, 2020
commit 139ea336c7f49a3246813238e388e164b80de4da
7 changes: 7 additions & 0 deletions .changeset/strong-cooks-drum.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
'@emotion/native': major
'@emotion/primitives': major
'@emotion/primitives-core': major
---

`StyleSheet.create` is used now under the hood. This means that when used in combination with React Native Web atomic class names are applied on components instead of inline styles.
56 changes: 12 additions & 44 deletions packages/native/test/__snapshots__/native-styled.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,7 @@ exports[`Emotion native styled primitive should work with \`withComponent\` 1`]
decor="hotpink"
style={
Array [
Object {
"color": "hotpink",
},
77,
undefined,
]
}
Expand All @@ -21,9 +19,7 @@ exports[`Emotion native styled should pass props in withComponent 1`] = `
color="green"
style={
Array [
Object {
"backgroundColor": "green",
},
81,
undefined,
]
}
Expand All @@ -35,9 +31,7 @@ exports[`Emotion native styled should pass props in withComponent 2`] = `
color="hotpink"
style={
Array [
Object {
"backgroundColor": "hotpink",
},
82,
undefined,
]
}
Expand All @@ -55,12 +49,7 @@ exports[`Emotion native styled should render <Image /> 1`] = `
}
style={
Array [
Object {
"borderBottomLeftRadius": 2,
"borderBottomRightRadius": 2,
"borderTopLeftRadius": 2,
"borderTopRightRadius": 2,
},
83,
undefined,
]
}
Expand All @@ -71,9 +60,7 @@ exports[`Emotion native styled should render primitive with style prop 1`] = `
<Text
style={
Array [
Object {
"color": "hotpink",
},
77,
Object {
"padding": 10,
},
Expand All @@ -89,10 +76,7 @@ exports[`Emotion native styled should render styles correctly from all nested st
backgroundColor="blue"
style={
Array [
Object {
"backgroundColor": "blue",
"color": "hotpink",
},
86,
undefined,
]
}
Expand All @@ -106,13 +90,7 @@ exports[`Emotion native styled should render the primitive on changing the props
decor="hotpink"
style={
Array [
Object {
"color": "hotpink",
"paddingBottom": 20,
"paddingLeft": 20,
"paddingRight": 20,
"paddingTop": 20,
},
76,
undefined,
]
}
Expand All @@ -126,11 +104,7 @@ exports[`Emotion native styled should render the primitive when styles applied u
back="red"
style={
Array [
Object {
"backgroundColor": "red",
"color": "red",
"fontSize": 20,
},
74,
Object {
"fontSize": 40,
},
Expand All @@ -145,9 +119,7 @@ exports[`Emotion native styled should style any other component 1`] = `
<Text
style={
Array [
Object {
"color": "hotpink",
},
77,
undefined,
]
}
Expand All @@ -160,10 +132,8 @@ exports[`Emotion native styled should work with StyleSheet.create API 1`] = `
<Text
style={
Array [
Object {
"fontSize": 10,
},
74,
79,
78,
]
}
>
Expand All @@ -175,9 +145,7 @@ exports[`Emotion native styled should work with theming from @emotion/react 1`]
<Text
style={
Array [
Object {
"color": "magenta",
},
75,
undefined,
]
}
Expand Down
123 changes: 76 additions & 47 deletions packages/native/test/native-css.test.js
Original file line number Diff line number Diff line change
@@ -1,105 +1,134 @@
import { css } from '@emotion/native'
import { StyleSheet } from 'react-native'

jest.mock('react-native')

let returnArguments = (...args) => args

describe('Emotion native css', () => {
test('basic', () => {
expect(css`
color: hotpink;
${{ backgroundColor: 'green' }};
`).toEqual({ color: 'hotpink', backgroundColor: 'green' })
expect(css({ color: 'green' })).toEqual({ color: 'green' })
expect(css([{ color: 'green' }, `background-color:yellow;`])).toEqual({
expect(
StyleSheet.flatten(css`
color: hotpink;
${{ backgroundColor: 'green' }};
`)
).toEqual({ color: 'hotpink', backgroundColor: 'green' })
expect(StyleSheet.flatten(css({ color: 'green' }))).toEqual({
color: 'green'
})
expect(
StyleSheet.flatten(css([{ color: 'green' }, `background-color:yellow;`]))
).toEqual({
color: 'green',
backgroundColor: 'yellow'
})
expect(css([{ color: 'green' }])).toEqual({ color: 'green' })
expect(StyleSheet.flatten(css([{ color: 'green' }]))).toEqual({
color: 'green'
})
})

test('order with string and object', () => {
// this test checks the keys instead of the objects
// because we care about the order of the keys
expect(
// $FlowFixMe
Object.keys(
css({ color: 'green' }, `background-color:yellow;`, { flex: 2 })
StyleSheet.flatten(
css({ color: 'green' }, `background-color:yellow;`, { flex: 2 })
)
)
).toEqual(['color', 'backgroundColor', 'flex'])
expect(
// $FlowFixMe
Object.keys(
css([
[{ color: 'green' }, `background-color:yellow;`],
{
flex: 2
}
])
StyleSheet.flatten(
css([
[{ color: 'green' }, `background-color:yellow;`],
{
flex: 2
}
])
)
)
).toEqual(['color', 'backgroundColor', 'flex'])
expect(
// $FlowFixMe
Object.keys(
css([
{ color: 'green' },
[
`background-color:yellow;`,
{
flex: 2
}
]
])
StyleSheet.flatten(
css([
{ color: 'green' },
[
`background-color:yellow;`,
{
flex: 2
}
]
])
)
)
).toEqual(['color', 'backgroundColor', 'flex'])
expect(
// $FlowFixMe
Object.keys(
css([
{ color: 'green' },
[
{ flex: 8 },
`background-color:yellow;`,
[`flex-grow: 1;`, { flexDirection: 'row' }]
]
])
StyleSheet.flatten(
css([
{ color: 'green' },
[
{ flex: 8 },
`background-color:yellow;`,
[`flex-grow: 1;`, { flexDirection: 'row' }]
]
])
)
)
).toEqual(['color', 'flex', 'backgroundColor', 'flexGrow', 'flexDirection'])
})

it('allows function interpolations when this.mergedProps is defined', () => {
expect(
css.call({ thing: true }, props => ({
color: props.thing && 'hotpink'
}))
StyleSheet.flatten(
css.call({ thing: true }, props => ({
color: props.thing && 'hotpink'
}))
)
).toEqual({ color: 'hotpink' })
})

it('works with nested functions', () => {
expect(
css.call({ thing: true }, props => () => ({
color: props.thing && 'hotpink'
}))
StyleSheet.flatten(
css.call({ thing: true }, props => () => ({
color: props.thing && 'hotpink'
}))
)
).toEqual({ color: 'hotpink' })
})

it('works with functions in tagged template literals', () => {
expect(
css.call(
{},
...returnArguments`
StyleSheet.flatten(
css.call(
{},
...returnArguments`
color: ${() => 'hotpink'};
`
)
)
).toEqual({ color: 'hotpink' })
})

test('last arg falsy and string before that', () => {
expect(css('color:hotpink;', false)).toEqual({ color: 'hotpink' })
expect(StyleSheet.flatten(css('color:hotpink;', false))).toEqual({
color: 'hotpink'
})
})

test('falsy value in the middle', () => {
expect(
css`
StyleSheet.flatten(css`
color: ${false};
background-color: hotpink;
`
`)
).toEqual({ backgroundColor: 'hotpink' })
})

Expand All @@ -108,10 +137,10 @@ describe('Emotion native css', () => {
color: hotpink;
`
expect(
css`
StyleSheet.flatten(css`
background-color: green;
${firstStyle};
`
`)
).toEqual({ backgroundColor: 'green', color: 'hotpink' })
})

Expand All @@ -128,7 +157,7 @@ describe('Emotion native css', () => {
// color: red;
`

expect(styles).toEqual({ color: 'hotpink' })
expect(anotherStyles).toEqual({ fontSize: 10 })
expect(StyleSheet.flatten(styles)).toEqual({ color: 'hotpink' })
expect(StyleSheet.flatten(anotherStyles)).toEqual({ fontSize: 10 })
})
})
10 changes: 9 additions & 1 deletion packages/primitives-core/src/css.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { interleave } from './utils'
// this is done so we don't create a new
// handleInterpolation function on every css call
let styles
let generated = {}
let buffer = ''
let lastType

Expand Down Expand Up @@ -102,7 +103,14 @@ export function createCss(StyleSheet: Object) {
buffer = prevBuffer
}

return StyleSheet.flatten(styles)
const hash = JSON.stringify(styles)
if (!generated[hash]) {
const styleSheet = StyleSheet.create({
generated: StyleSheet.flatten(styles)
})
generated[hash] = styleSheet.generated
}
return generated[hash]
}
}

Expand Down
Loading