Skip to content

Latest commit

 

History

History
145 lines (106 loc) · 5.96 KB

gatsby.md

File metadata and controls

145 lines (106 loc) · 5.96 KB

Use Twin with Gatsby + Styled Components

🔥 View the Gatsby + Styled Components + Tailwind Twin starter for usage examples

Getting started

1. Install Gatsby

npx gatsby new gatsby-site

2. Install the dependencies

npm install --save twin.macro styled-components gatsby-plugin-styled-components
Yarn instructions
yarn add twin.macro styled-components gatsby-plugin-styled-components

3. Add the global styles

Projects using Twin also use the Tailwind preflight base styles to smooth over cross-browser inconsistencies.

Twin adds the preflight base styles with the GlobalStyles import which you can add to a layout file in src/components/Layout.js:

// src/components/Layout.js
import React from 'react'
import { GlobalStyles } from 'twin.macro'

const Layout = ({ children }) => (
  <>
    <GlobalStyles />
    {children}
  </>
)

export default Layout

Then in your pages, wrap your content with the layout:

// src/pages/index.js
import Layout from './../components/Layout'

const App = () => <Layout>{/* ... */}</Layout>

GlobalStyles also includes some @keyframes so the animate-xxx classes have animations. But if you’re not using the animate classes then you can avoid adding the extra keyframes.

4. Add gatsby-plugin-styled-components to the gatsby config

// gatsby-config.js
module.exports = {
  plugins: [`gatsby-plugin-styled-components`],
}

5. Add the recommended config

Twin’s recommended config can be added in a couple of different places.

a) In your package.json:

// package.json
"babelMacros": {
    "twin": {
      "config": "tailwind.config.js",
      "preset": "styled-components",
      "autoCssProp": true,
      "debugProp": true,
      "debugPlugins": false,
      "debug": false,
    }
},

b) Or in a new file named babel-plugin-macros.config.js placed in your project root:

// babel-plugin-macros.config.js
module.exports = {
  twin: {
    config: 'tailwind.config.js',
    preset: 'styled-components',
    autoCssProp: true,
    debugProp: true,
    debugPlugins: false,
    debug: false,
  },
}

6. Complete the TypeScript support (optional)

Twin comes with types for every import except the css and styled imports.

Add the remaining types →

Options

Name Type Default Description
config string "tailwind.config.js" The path to your Tailwind config
preset string "emotion" The css-in-js library behind the scenes - also supports 'styled-components' and 'goober'
autoCssProp boolean false This code automates the import of 'styled-components/macro' so you can use their css prop. Enable it if you're using styled-components with React, CRA or Gatsby. If you're using Emotion, setting to true does nothing.
hasSuggestions boolean true Display class suggestions when a class can't be found
debugPlugins boolean false Display generated class information in your terminal from your plugins
debugProp boolean false Add a prop to your elements in development so you can see the original tailwind classes, eg: <div data-tw="bg-black" />
debug boolean false Display information in your terminal about the Tailwind class conversions

If twin’s default styled and css imports need to be adjusted, you can do so with the following config:

{
  styled: { import: "default", from: "styled-components" },
  css: { import: "css", from: "styled-components/macro" }
}

Note: Make sure you remove the preset option as that value disables the styled + css options.

Next steps

Installation guides