<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: 🐟</title>
    <description>The latest articles on DEV Community by 🐟 (@jesuissuyaa).</description>
    <link>https://dev.to/jesuissuyaa</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F298584%2F36df327a-cecc-434b-8bd9-f88c14cd04a6.jpg</url>
      <title>DEV Community: 🐟</title>
      <link>https://dev.to/jesuissuyaa</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/jesuissuyaa"/>
    <language>en</language>
    <item>
      <title>customizing Chakra UI theme in a Gatsby project</title>
      <dc:creator>🐟</dc:creator>
      <pubDate>Tue, 19 May 2020 18:49:38 +0000</pubDate>
      <link>https://dev.to/jesuissuyaa/customizing-chakra-ui-theme-in-a-gatsby-project-3jmc</link>
      <guid>https://dev.to/jesuissuyaa/customizing-chakra-ui-theme-in-a-gatsby-project-3jmc</guid>
      <description>&lt;p&gt;So this is going to be my first post on DEV.to 🎉&lt;/p&gt;

&lt;p&gt;In this article, I'm going to explain how to add your own custom themes to your Gatsby project.&lt;/p&gt;

&lt;h2&gt;
  
  
  TL;DR
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;create a new file in &lt;code&gt;src/gatsby-plugin-chakra-ui/theme.js&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;import original theme from &lt;code&gt;@chakra-ui/core&lt;/code&gt; &amp;amp; add your own properties&lt;/li&gt;
&lt;li&gt;restart server&lt;/li&gt;
&lt;/ol&gt;

&lt;h2&gt;
  
  
  prerequisites
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;gatsby project is set up &lt;/li&gt;
&lt;li&gt;
&lt;code&gt;gatsby-plugin-chakra-ui&lt;/code&gt; is added to your project&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;If you haven't added the plugin yet, check out the &lt;a href="https://www.gatsbyjs.org/packages/gatsby-plugin-chakra-ui"&gt;docs&lt;/a&gt; on how to do so.&lt;/p&gt;

&lt;h2&gt;
  
  
  step 1: add a theme.js file
&lt;/h2&gt;

&lt;p&gt;Create a a &lt;code&gt;theme.js&lt;/code&gt; file under &lt;code&gt;src/gatsby-plugin-chakra-ui/&lt;/code&gt;.&lt;br&gt;
(Most likely you need add the &lt;code&gt;gatsby-plugin-chakra-ui&lt;/code&gt; folder under &lt;code&gt;src&lt;/code&gt; )&lt;/p&gt;

&lt;p&gt;This will allow Gatsby to &lt;strong&gt;shadow&lt;/strong&gt; the &lt;code&gt;theme.js&lt;/code&gt; file.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Shadowing&lt;/strong&gt; is a concept introduced by Gatsby so users can use their own themes.&lt;br&gt;
What this does is that it replaces a file in the webpack bundle with a file in the &lt;code&gt;src&lt;/code&gt; directory.&lt;br&gt;
For example, if you have a plugin named &lt;code&gt;gatsby-plugin-awesome&lt;/code&gt; and you want to replace &lt;code&gt;awesomeFile.js&lt;/code&gt; with your own version, you would create a new file in &lt;code&gt;src/gatsby-plugin-awesome/awesomeFile.js&lt;/code&gt;.&lt;br&gt;
Then you can use your own version of &lt;code&gt;awesomeFile.js&lt;/code&gt; in your project instead of the default version provided by the plugin.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://github.com/chakra-ui/chakra-ui/issues/347#issuecomment-579620254"&gt;This comment on Github Issues&lt;/a&gt; is also another explanation on shadowing. &lt;/p&gt;
&lt;h2&gt;
  
  
  step 2: edit &lt;code&gt;theme.js&lt;/code&gt;
&lt;/h2&gt;

&lt;p&gt;This is where we write our custom theme.&lt;/p&gt;

&lt;p&gt;I'm going to add a custom color called "brandPurple" that has a value of "#673FB4".&lt;/p&gt;

&lt;p&gt;First, we'll copy &amp;amp; paste the code from the &lt;a href="https://www.gatsbyjs.org/packages/gatsby-plugin-chakra-ui/"&gt;plugin docs&lt;/a&gt;.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight"&gt;&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// src/gatsby-plugin-chakra-ui/theme.js&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{};&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="k"&gt;default&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;p&gt;This code is overwriting the default theme provided by the plugin with an empty theme.&lt;/p&gt;

&lt;p&gt;⚠️ Don't try to run &lt;code&gt;gatsby develop&lt;/code&gt; with this code yet; you're going to see a bunch of errors because the theme object is &lt;code&gt;{}&lt;/code&gt;, and none of the previously available values can be accessed.&lt;/p&gt;

&lt;p&gt;Next, we're going to add the default theme provided by Chakra UI to our custom theme.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight"&gt;&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// src/gatsby-plugin-chakra-ui/theme.js&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="nx"&gt;defaultTheme&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;@chakra-ui/core&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="p"&gt;...&lt;/span&gt;&lt;span class="nx"&gt;defaultTheme&lt;/span&gt;
&lt;span class="p"&gt;};&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="k"&gt;default&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;p&gt;We rename &lt;code&gt;theme as defaultTheme&lt;/code&gt; because we don't want names to clash for Chakra UI's theme with our own variable &lt;code&gt;theme&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;You can run &lt;code&gt;gatsby develop&lt;/code&gt; with this code now, but you won't see any changes, because we haven't added anything to our theme yet.&lt;/p&gt;

&lt;p&gt;Finally, we add our own "brandPurple" color like so:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight"&gt;&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// src/gatsby-plugin-awesome/theme.js&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="nx"&gt;defaultTheme&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;@chakra-ui/core&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="p"&gt;...&lt;/span&gt;&lt;span class="nx"&gt;defaultTheme&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;colors&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="p"&gt;...&lt;/span&gt;&lt;span class="nx"&gt;defaultTheme&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;colors&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;brandPurple&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;#673FB4&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="k"&gt;default&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;h3&gt;
  
  
  final code
&lt;/h3&gt;



&lt;div class="highlight"&gt;&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// src/gatsby-plugin-awesome/theme.js&lt;/span&gt;

&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="nx"&gt;defaultTheme&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;@chakra-ui/core&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="p"&gt;...&lt;/span&gt;&lt;span class="nx"&gt;defaultTheme&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;colors&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="p"&gt;...&lt;/span&gt;&lt;span class="nx"&gt;defaultTheme&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;colors&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;brandPurple&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;#673FB4&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="k"&gt;default&lt;/span&gt; &lt;span class="nx"&gt;theme&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;h2&gt;
  
  
  step 3: restart server
&lt;/h2&gt;

&lt;p&gt;In order for the &lt;code&gt;theme.js&lt;/code&gt; to shadow, we need to restart the server.&lt;br&gt;
Go ahead and hit Ctrl+C (or other shortcut keys depending on your computer), and enter &lt;code&gt;gatsby develop&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;At this point, we're all set and we can use our new "brandPurple" color just like any other theme colors provided by Chakra UI.&lt;/p&gt;

&lt;p&gt;Here's an example test code.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight"&gt;&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// src/pages/testPage.js&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="nx"&gt;React&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;react&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;Box&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;@chakra-ui/core&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;TestPage&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;Box&lt;/span&gt; &lt;span class="nx"&gt;bg&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;brandPurple&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="nx"&gt;here&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;s the new color!
  &amp;lt;/Box&amp;gt;
}

export default TestPage
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;p&gt;see also: &lt;a href=""&gt;plugin docs&lt;/a&gt;, &lt;a href=""&gt;Chakra UI docs on custom themes&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Feel free to leave a comment or hit me up on Twitter if you have any questions.&lt;/p&gt;

</description>
      <category>gatsby</category>
      <category>react</category>
      <category>webdev</category>
      <category>beginners</category>
    </item>
  </channel>
</rss>
