From 7e5d8db13cb18ac2d22f8a606824d9ec6ff8cdc6 Mon Sep 17 00:00:00 2001 From: Kye Hohenberger Date: Mon, 25 Sep 2017 20:36:51 -0600 Subject: [PATCH] Support functions as return values in interpolations --- packages/emotion/src/index.js | 4 ++++ packages/emotion/test/__snapshots__/css.test.js.snap | 10 ++++++++++ packages/emotion/test/css.test.js | 7 +++++++ .../test/__snapshots__/index.test.js.snap | 12 ++++++++++++ packages/react-emotion/test/index.test.js | 9 +++++++++ 5 files changed, 42 insertions(+) diff --git a/packages/emotion/src/index.js b/packages/emotion/src/index.js index 0e0a6d874..2d4337adc 100644 --- a/packages/emotion/src/index.js +++ b/packages/emotion/src/index.js @@ -116,6 +116,10 @@ function handleInterpolation( return '' } + if (typeof interpolation === 'function') { + return interpolation() + } + if (typeof interpolation === 'object') { return createStringFromObject(interpolation) } diff --git a/packages/emotion/test/__snapshots__/css.test.js.snap b/packages/emotion/test/__snapshots__/css.test.js.snap index 960880540..31e8663ce 100644 --- a/packages/emotion/test/__snapshots__/css.test.js.snap +++ b/packages/emotion/test/__snapshots__/css.test.js.snap @@ -423,6 +423,16 @@ exports[`css registered styles as nested selector value in object 1`] = ` /> `; +exports[`css return function in interpolation 1`] = ` +.glamor-0 { + color: blue; +} + +
+`; + exports[`css weakmap 1`] = ` .glamor-0 { display: -webkit-box; diff --git a/packages/emotion/test/css.test.js b/packages/emotion/test/css.test.js index 1762e287b..09a3f4737 100644 --- a/packages/emotion/test/css.test.js +++ b/packages/emotion/test/css.test.js @@ -290,4 +290,11 @@ describe('css', () => { const tree2 = renderer.create(
).toJSON() expect(tree2).toMatchSnapshot() }) + + test('return function in interpolation', () => { + const cls1 = css`color: ${() => 'blue'};` + + const tree = renderer.create(
).toJSON() + expect(tree).toMatchSnapshot() + }) }) diff --git a/packages/react-emotion/test/__snapshots__/index.test.js.snap b/packages/react-emotion/test/__snapshots__/index.test.js.snap index d74be831e..6c9d3b564 100644 --- a/packages/react-emotion/test/__snapshots__/index.test.js.snap +++ b/packages/react-emotion/test/__snapshots__/index.test.js.snap @@ -312,6 +312,18 @@ exports[`styled higher order component 1`] = ` /> `; +exports[`styled inline function return value is a function 1`] = ` +.glamor-0 { + font-size: 20px; +} + +

+ hello world +

+`; + exports[`styled innerRef 1`] = ` .glamor-0 { font-size: 12px; diff --git a/packages/react-emotion/test/index.test.js b/packages/react-emotion/test/index.test.js index 7c4dad4ee..d797e221d 100644 --- a/packages/react-emotion/test/index.test.js +++ b/packages/react-emotion/test/index.test.js @@ -81,6 +81,15 @@ describe('styled', () => { expect(tree).toMatchSnapshot() }) + test('inline function return value is a function', () => { + const fontSize = 20 + const H1 = styled('h1')`font-size: ${() => fontSize}px;` + + const tree = renderer.create(

hello world

).toJSON() + + expect(tree).toMatchSnapshot() + }) + test('call expression', () => { const fontSize = 20 const H1 = styled('h1')`font-size: ${fontSize}px;`