<?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>Forem: Miguel Haba</title>
    <description>The latest articles on Forem by Miguel Haba (@mihaben).</description>
    <link>https://forem.com/mihaben</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%2F256252%2F6ed9f8e9-8fd9-43e8-92c9-3bb181401a1c.jpeg</url>
      <title>Forem: Miguel Haba</title>
      <link>https://forem.com/mihaben</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/mihaben"/>
    <language>en</language>
    <item>
      <title>Building a galery with Gatsby, Google Sheets and Netlify</title>
      <dc:creator>Miguel Haba</dc:creator>
      <pubDate>Mon, 11 Nov 2019 17:12:47 +0000</pubDate>
      <link>https://forem.com/mihaben/building-a-galery-with-gatsby-google-sheets-and-netlify-254l</link>
      <guid>https://forem.com/mihaben/building-a-galery-with-gatsby-google-sheets-and-netlify-254l</guid>
      <description>&lt;p&gt;Did you know you can use Google Sheets as a database? Well, you can use this service practically as if it were a &lt;a href="https://en.wikipedia.org/wiki/Headless_content_management_system"&gt;headless CMS&lt;/a&gt; (with some limitations) through the API offered by Google. If you need to make a static page with dynamic content in a simple way, without complex implementations and with a low consumption of resources, I believe that Google Sheets, along with Gatsby, should be an alternative to consider. In this post I will show you how to build a gallery of products with these two technologies, and eventually use the Netlify service as hosting and CD service (Continuous Deployment).&lt;/p&gt;

&lt;h1&gt;
  
  
  Knowing the protagonists
&lt;/h1&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;&lt;a href="https://www.gatsbyjs.org/"&gt;Gatsby.js&lt;/a&gt;:&lt;/strong&gt; Gatsby is a free and open source framework based on React that helps developers build static websites. In addition, is a JAMstack technology, a modern web development architecture based on client-side JavaScript, reusable APIs, and prebuilt Markup.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;&lt;a href="https://docs.google.com/spreadsheets/u/0/"&gt;Google Sheets&lt;/a&gt;:&lt;/strong&gt; Free browser-based Google service for creating spreadsheets.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;&lt;a href="https://www.netlify.com/"&gt;Netlify&lt;/a&gt;:&lt;/strong&gt; Netlify offers serverless hosting and backend services for static websites, among other things.&lt;/li&gt;
&lt;/ul&gt;

&lt;h1&gt;
  
  
  Building our gallery
&lt;/h1&gt;

&lt;p&gt;In this small project, we will build a simple product gallery with Gatsby, using a Google Sheets spreadsheet as a database. Finally, we will use the Netlify service to build and deploy our application in a simple and fast way. 👌&lt;/p&gt;

&lt;p&gt;As you already know, Gatsby.js builds your site as "static" files &lt;em&gt;(html, css and js)&lt;/em&gt;, this means that our application will only query our spreadsheet in the build process, and not every time a new user enters the page. Wait... what?&lt;/p&gt;

&lt;p&gt;This image will help you understand it better:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--9FSMx7wu--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/ze9lto535qplnc8uqxyh.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--9FSMx7wu--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/ze9lto535qplnc8uqxyh.png" alt="architecture schema"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;As &lt;a href="https://jamstack.org/"&gt;JAMstack&lt;/a&gt; architecture, we can find advantages and disadvantages, the main advantages are obviously the loading speed and low consumption of resources on our server, as we simply return to the user static files previously generated, while avoiding multiple calls to the database. On the other hand, we will lose some dynamism, as our website will not reflect the status of our database immediately, but we must previously make a new build to re-generate our static files.&lt;/p&gt;

&lt;p&gt;You'll need to analyze your project and the nature of your data beforehand to see if Gatsby is the best solution.&lt;/p&gt;

&lt;p&gt;Having clarified this, &lt;strong&gt;let's start!&lt;/strong&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  🗂️ Create your Spreadsheet
&lt;/h2&gt;

&lt;p&gt;First of all, we must create our spreadsheet:&lt;/p&gt;

&lt;p&gt;1- Log in to &lt;a href="https://docs.google.com/spreadsheets/u/0/"&gt;Google Drive&lt;/a&gt; with your Google Account&lt;br&gt;
2- Click on "New", and add a new spreadsheet&lt;br&gt;
3- Depending on the information you want to store, create the appropriate columns.&lt;br&gt;
4- Add a new row for each element you want to store.&lt;br&gt;
5- Click on the "Share" button, and save the id of your spreadsheet. You will find this id in the url that will be generated to share your project: &lt;code&gt;https://docs.google.com/spreadsheets/d/id&lt;/code&gt;. This id will be used later to connect from Gatsby.&lt;/p&gt;

&lt;p&gt;This is an example of my spreadsheet:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--WTmdBepO--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/hbdllkjwo4mi4uvbqm2g.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--WTmdBepO--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/hbdllkjwo4mi4uvbqm2g.png" alt="spreadsheet"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  👨🏻‍💻 Create your project with Gatsby
&lt;/h2&gt;

&lt;p&gt;We already have our spreadsheet, it's time to create our project.&lt;/p&gt;

&lt;p&gt;1- Install the Gatsby CLI&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;&lt;code&gt;$ npm install -g gatsby-cli&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;2- Create a new project.&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;&lt;code&gt;$ gatsby new my-gallery&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;3- Change directories into site folder.&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;&lt;code&gt;$ cd my-gallery&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;4- Start development server &lt;code&gt;(localhost:8000)&lt;/code&gt;. By the way, Gatsby has hot-reloading.&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;&lt;code&gt;$ gatsby develop&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;h2&gt;
  
  
  🔑 Get your Google Drive API Key
&lt;/h2&gt;

&lt;p&gt;To be able to query our spreadsheet, we must first get a &lt;strong&gt;Google Drive API Key&lt;/strong&gt;. It's quite simple, just follow these steps:&lt;/p&gt;

&lt;p&gt;1- Go to the &lt;a href="https://console.cloud.google.com/"&gt;Google Cloud Platform&lt;/a&gt;&lt;br&gt;
2- Create a new project.&lt;br&gt;
3- Click “Enable API”. Search for and enable the “Google Drive API”.&lt;br&gt;
4- Create credentials for a “Web Server” to access application data.&lt;br&gt;
5- Name the service account and grant it a project role of “Editor”.&lt;br&gt;
6- Download the JSON file and rename it to &lt;code&gt;client_secret.json&lt;/code&gt;.&lt;br&gt;
7- Create a new &lt;code&gt;/credentials&lt;/code&gt; directory into your Gatsby project and move inside the JSON file.&lt;/p&gt;
&lt;h1&gt;
  
  
  ⚙️ Configure your project
&lt;/h1&gt;

&lt;p&gt;Once our API Key is obtained, we will have to configure our project so that it can run it.&lt;/p&gt;

&lt;p&gt;Install the &lt;a href="https://www.gatsbyjs.org/packages/gatsby-source-google-sheets/"&gt;gatsby-source-google-sheets&lt;/a&gt; package&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;&lt;code&gt;$ npm install gatsby-source-google-sheets&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;p&gt;Once installed, open the file &lt;code&gt;gatsby-config.js&lt;/code&gt; and add the following information for its correct configuration:&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;// gatsby-config.js&lt;/span&gt;
&lt;span class="c1"&gt;// ...&lt;/span&gt;
&lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nl"&gt;resolve&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;gatsby-source-google-sheets&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="nx"&gt;options&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="nl"&gt;spreadsheetId&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;we got this id in the first step&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
        &lt;span class="nx"&gt;worksheetTitle&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;worksheet tab name&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
        &lt;span class="nx"&gt;credentials&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;require&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;./credentials/client_secret.json&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="c1"&gt;// ...&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;h2&gt;
  
  
  🔍 Make your query
&lt;/h2&gt;

&lt;p&gt;Congratulations! If you have reached this point it means we are now ready to make our query 🥳.&lt;/p&gt;

&lt;p&gt;Before we continue, you should know that Gatsby uses &lt;a href="https://graphql.org/"&gt;GraphQL&lt;/a&gt; for data management, it is a very interesting query and data manipulation language that has reached some popularity in recent years, if you wish, you can learn a little more about data management in Gatsby in this link: &lt;a href="https://www.gatsbyjs.org/tutorial/part-four/"&gt;Data in Gatsby&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;By much simplification, this would be our &lt;code&gt;index.js&lt;/code&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;// index.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="p"&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;graphql&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;gatsby&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="kd"&gt;get&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;lodash&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt; &lt;span class="c1"&gt;// Optional&lt;/span&gt;

&lt;span class="c1"&gt;// Item Component&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;Item&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;({&lt;/span&gt;&lt;span class="nx"&gt;title&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;imageSrc&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;div&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;h1&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;title&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/h1&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;    &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;img&lt;/span&gt; &lt;span class="nx"&gt;src&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;imageSrc&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="nx"&gt;alt&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;title&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="sr"&gt;/&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;  &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/div&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

&lt;span class="c1"&gt;// Index Page Component&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;IndexPage&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="nx"&gt;data&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="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;nodes&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kd"&gt;get&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;data&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;allGoogleSheetProjectsRow.edges&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="k"&gt;return&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;div&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;nodes&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;map&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;node&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;Item&lt;/span&gt; &lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;node&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;id&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="p"&gt;{...&lt;/span&gt;&lt;span class="nx"&gt;node&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="sr"&gt;/&amp;gt;&lt;/span&gt;&lt;span class="se"&gt;)&lt;/span&gt;&lt;span class="sr"&gt;}&amp;lt;/&lt;/span&gt;&lt;span class="nx"&gt;div&lt;/span&gt;&lt;span class="o"&gt;&amp;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;IndexPage&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="c1"&gt;// GraphQL query to our spreadsheet&lt;/span&gt;
&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;query&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;graphql&lt;/span&gt;&lt;span class="s2"&gt;`
  query {
    allGoogleSheetProjectsRow {
      edges {
        node {
          id
          title
          imageSrc
        }
      }
    }
  }
`&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;



&lt;p&gt;If everything went well, you should be looking at the product listing at &lt;code&gt;localhost:8000&lt;/code&gt;. The style is now up to you 😊&lt;/p&gt;

&lt;h2&gt;
  
  
  🚀 Build &amp;amp; Deploy with Netlify
&lt;/h2&gt;

&lt;p&gt;In my opinion, Netlify is a great platform, not only will it serve us as hosting, but it will also serve us as a CD tool (Continuous Deployment).&lt;/p&gt;

&lt;p&gt;1- Create a new repository in Github, Gitlab or Bitbucket and &lt;code&gt;push&lt;/code&gt; your code.&lt;br&gt;
2- Create a new Netlify user account. It's free.&lt;br&gt;
3- Log in to your account, and click on the "New site from Git" button.&lt;br&gt;
4- Follow the steps of the form:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Connect your Git provider&lt;/li&gt;
&lt;li&gt;Select your repository and branch&lt;/li&gt;
&lt;li&gt;Verify that the command to make the build and the public folder are correct:&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--yt25p_35--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/zrv8715hm6tg9gvsuc5s.png" alt="Netlify"&gt;
5- Click on the "Deploy" button, and that's it! 🚀&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  So... what next?
&lt;/h3&gt;

&lt;p&gt;Once this is done, Netlify will proceed with the build and deploy of the application (it may take a few minutes). The process may be summarized in the following steps:&lt;/p&gt;

&lt;p&gt;1- Netlify will &lt;code&gt;pull&lt;/code&gt; your project.&lt;br&gt;
2- Run &lt;code&gt;$ gatsby build&lt;/code&gt; to build the application. This is where the query is made and the static files are generated.&lt;br&gt;
3- The generated static files are stored in the &lt;code&gt;/public&lt;/code&gt; folder.&lt;br&gt;
4- A deploy of the &lt;code&gt;/public&lt;/code&gt; folder is made on the Netlify hosting.&lt;/p&gt;

&lt;p&gt;Simple, isn't it?&lt;/p&gt;

&lt;h1&gt;
  
  
  Keep learning!
&lt;/h1&gt;

&lt;p&gt;I hope you enjoyed this article! &lt;/p&gt;

&lt;p&gt;If you want to learn more about &lt;strong&gt;Gatsby&lt;/strong&gt;, &lt;strong&gt;React&lt;/strong&gt; or &lt;strong&gt;GraphQL&lt;/strong&gt; and keep up to date with the latest trends, I recommend you take a look at my last project, &lt;a href="https://codetalks.tv/"&gt;CodeTalks TV&lt;/a&gt;, a video platform for developers that brings together the best dev talks given around the world.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://codetalks.tv/react"&gt;React Talks&lt;/a&gt;&lt;br&gt;
&lt;a href="https://codetalks.tv/ja-mstack"&gt;JAMstack Talks&lt;/a&gt;&lt;br&gt;
&lt;a href="https://codetalks.tv/graphql"&gt;GraphQL Talks&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://codetalks.tv/"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--vfys-Hdr--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://thepracticaldev.s3.amazonaws.com/i/epbsqpap0uv6kz3m4k3s.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

</description>
      <category>gatsby</category>
      <category>react</category>
      <category>graphql</category>
      <category>javascript</category>
    </item>
  </channel>
</rss>
