Display a feed of Tweets on your website

Update October 2021:

To create a feed of tweets on your Webflow site, the simplest process is this:

  1. Create a CMS collection, where each item = a tweet (we'll call this collection "Tweets").
  2. Add a rich text element as a field in that collection.
  3. On the page where you want to have a feed, add a Collection List element.
  4. Link the List to your "Tweets" collection.
  5. Insert a rich text element into any one of the collection items.
  6. Link that rich text element to the rich text field in your collection.

Ben Tossell of Makerpad tweeted that he was looking for a way to create a feed of Tweets that all use a certain hashtag, for the sake of embedding it on a website. In the responses to his Tweet, it became clear that there isn’t an out of the box solution.

Turns out, you can build an embedded feed for yourself, with absolutely no code. Here's how.

The goal: We want a feed of Tweets that updates whenever someone uses a specific hashtag, like this.

Gif displaying a live feed of tweets

Tools needed:

  • Twitter
  • Zapier
  • Webflow CMS

Build Process:

  1. Set up a CMS Collection in Webflow
  2. Style a Div Block to look like an embedded Tweet
  3. Link the CMS Collection fields to elements of the embedded Tweet
  4. Create a Zap to pipe in new Tweets that use the hashtag

Create a CMS collection in Webflow

First, we need to create a new CMS collection in Webflow. The collection will need the fields shown below:

In a bit, we’ll use Zapier to pipe Tweets into our CMS collection, so that our site updates automagically when new Tweets include the hashtag we’d like to track.

But before that, we’ll create an instance of an item in our collection (aka one tweet) so that we can make sure everything will look just how we want it. This is how embedded tweets normally look and is what we want to imitate:

If you don’t need a how-to of styling the particular elements to make it look like an embedded tweet, skip the next section. Otherwise, below is the step by step process.

Skip to next step.

Style a Div Block to look like an embedded Tweet

Create a new page on your site (unless you’re embedding on an existing page). Then, add a Section element to the page. Next, drag a Div Block element into that section. Give that Div a class name. Because it will hold our Tweet, let’s call it something like “Tweet Div”.

Style the Tweet Div with these properties:

  • Display: Block
  • Top padding: 10px
  • Bottom margin: 40px
  • Width: 420px
  • Max-Width: 95%
  • Border radius: 5px
  • Border color: Silver
  • Border width: 1px

Then, center the Tweet Div by clicking the square icon next to the “Spacing” label on the right side of the screen.

Now, drag another Div Block into the Tweet Div, and give it its own class name, like “Top of Tweet”. Top of Tweet will hold our profile picture, name, and the Twitter icon.

We'll want it to look like this:

Give Top of Tweet these properties:

  • Display: flex
  • Justify: start (aka left)

Inside Top of Tweet, drag in an Image, a Heading, and another Image. These should be lined up horizontally.

Input a sample profile picture image and give it these properties:

  • Border radius: 20px
  • Left margin: 20px
  • Top margin: 2px
  • The rest of the margins set at 0.
  • Width: 20px
  • Height: 20px

Style the heading to get it to look how you’d like. On my site, it’s an H6 heading called “Author”, with the following properties:

  • Left padding: 10
  • All other margins and padding: 0

And 

You can download the Twitter icon here.

Upload the Twitter bird with these properties:

  • Width: 30px
  • Height: 30px
  • Left margin: Auto
  • Right margin: 30px

At this point, here how’s our Navigator should look:

Directly under the Top of Tweet Div Block, we’ll drag a Text block that we’ll fill with the Tweeter’s username (@handle). Give this a class like “Tweeter Handle”.

We want this to be a bit smaller than the Tweeter’s name, so decrease the font size and weight. Then, give it this spacing:

Under that, drag another Text block in for the Tweet’s actual content. Give this a class “Tweet Content”.

Make the text of Tweet Content slightly bigger and weightier. Otherwise, here is how the spacing should look:

Next, drag in another Text block, this time to hold the timestamp. As a reminder, this is the look we’re going for:

Give this a class called “Timestamp”. Make the weight of the font slightly less than the tweet itself, and change the color of the font to gray. Otherwise, give it these properties:

  • Bottom border: 1px, silver
  • Left padding: 20px
  • Bottom padding: 5px
  • All other padding and margin: 0px

Next, drag in a Div Block below the Timestamp, and give it the class “Bottom of Tweet”. Set its properties like this:

  • Display: flex
  • Justify: start (aka left)
  • Left margin: 20px
  • Top margin: 6px
  • All other margin and padding: 0px

Inside the Bottom of Tweet Div block, we’ll add an image. Upload a speech bubble or other icon that corresponds with a Twitter CTA. Next to the image, drag in a text block, and write a CTA like “Join the conversation”. Style the CTA so that it is blue and slightly bold.

If you’d like, you can add another text block with a "<" as a little CTA icon. You can space this out the right the same way we did with the Twitter icon.

That’s it for designing the way the Tweet itself should look. Here’s our navigator, with all our elements, at this point:

Connect the CMS collection to generate Tweets on site

Next, we’ll set up our CMS Collection to utilize all the elements we just made. It may be useful to add some dummy tweets to your CMS collection of Tweets. Webflow can add sample text for you, or you can just make up some fake tweets and add them to your collection. To add to your collection, click the CMS icon on the left side of the screen, click into your collection and click “Add X Dummy Items” (only if you have zero items in the collection) or click the blue button in the top right.

Add a Collection List to your page.

Connect your Collection List to a source by clicking on the Collection’s settings:

This will allow you to pull fields from particular CMS items into your page. Anytime a new item is added to your collection list, it will be dynamically added to the page. This allows you to update your site dynamically and without any manual effort!

Next, drag your Tweet Div into a collection item. 

Then, right click on the Tweet Div and turn it into a link block. We want the whole Tweet Div to link to the URL of the Tweet. We also want it to to open in a new tab.

Now, we can connect each of our elements (shown in the Navigator screenshot above) to fields in our collection. Here’s how:

Go through each element in the Tweet Div, and map them to their corresponding field.

If you added some Tweets to your collection, you should now see a Tweet Div for each of those tweet items in your collection, showing what looks like a feed of Tweets. Like this:

Pipe live data into your CMS collection to create a live feed

The last step in creating a live feed of tweets is to set up a way for new Tweets to be added to our CMS Collection. That way, when a new Tweet is added, it’ll show up on our page, styled the way we’ve styled all of these elements.

To do so, we’ll use Zapier.

Log into Zapier or create an account. Then click “Make a Zap”.

The basics of this Zap are shown here:

For step by step instructions, follow along with this video:

Essentially, we’re again mapping the fields from a sample Tweet to the fields of our CMS collection items. We don't want the item to be archived.

If you'd like to review Tweets before they're pushed live to your site, choose "Yes" for the Draft field. If you choose no, you'll have a truly live feed. If we set it up correctly, we’ll see a new CMS item back in Webflow (it may take a minute and you may need to refresh it).

And that's it. Next time you need a feed of Tweets on your site, use the process above to get something like this:

Gif displaying a live feed of tweets

Got questions? Join the conversation on Twitter 👇

Want more stuff like this? Put in your email and I'll send you another tutorial next week.