craftpulse / craft-tweet-feed
Get the latest tweets from a Twitter handle with your own design
Requires
- php: ^8.0.2
- craftcms/cms: ^4.0.0-beta.1
- guzzlehttp/oauth-subscriber: ^0.6.0
Requires (Dev)
- craftcms/phpstan: dev-main
This package is not auto-updated.
Last update: 2025-01-15 13:44:14 UTC
README
Get the latest tweets from a Twitter handle with your own design
Requirements
This plugin requires Craft CMS 3.5.0 or later. We utilise Guzzle 6 and up (7 included) and Twitter v2.0.
Installation
To install the plugin, follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Tell Composer to load the plugin:
composer require percipiolondon/craft-tweet-feed
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for Tweet.
Tweet Feed Overview
This plugin provides a Twitter feed from a specific Twitter handle.
Configuring Tweet Feed
To make this happen, you need to make an app in the Developers Portal. Make sure it's not a standalone app because we use the Twitter API 2.0.
Create your keys and tokens and paste them into the plugin settings page. Make sure you create an OAuth 1.0a and generate the access tokens.
Besides the keys and tokens, we also require the Twitter user id to provide the tweets from a specific handle. If you don't know the id, you can look it op on this site.
You can provide all of this inside of your environment file.
Using Tweet Feed
To make use of Tweet Feed, we created a Craft variable to fetch.
The craft.tweetfeed.tweets()
function can have 3 parameters.
First param: amount of results (default: 100)
The first one will ask for the number of results you want to receive. There's a maximum of 100 results that can be fetched. Here's a list of all the Twitter API v2 rate limits.
example: 3
Second param: types of fields (default: null)
The types of fields are the data you want to receive from Twitter. By default, the id and text are provided. We also add the entities
so you can already use the tweet url. To know all the options, you can visit the Tweet object page.
Always provide the list with a comma as separation.
example: author_id,context_annotations
Third param: extra parameters (default: '')
If you want to extend the query, you can add extra parameters to the url. The max_results
and tweet.fields
are already used in the previously shown parameters. To know which kind of parameters excists, you can visit the GET /2/users/:id/tweets page and scroll to 'Query parameters'.
To provide these parameters for our plugin, use the following example. You can tie parameters to each other by using &
.
example: &exclude=retweets,replies&user.fields=id
Twig example
{% set tweets = craft.tweetfeed.tweets(3,'author_id,context_annotations','&exclude=retweets,replies&user.fields=id') %}
{% for tweet in tweets %}
<div>
<h3>{{ tweet.text }}</h3>
</div>
{% endfor %}
urlify twig extension filter
If you want to parse the URLs and hashtags into clickable urls, you can use the | urlify
filter. You need to pass down the full object to get the filtered tweet text back.
{% set tweets = craft.tweetfeed.tweets(3,'author_id,context_annotations','&exclude=retweets,replies&user.fields=id') %}
{% for tweet in tweets %}
<div>
<h3>{{- tweet | urlify | raw -}}</h3>
</div>
{% endfor %}
Use cache tag to reduce calls
There is a limit on API calls per day. If you have a high traffic site, we recommend using the cache
tag from CraftCMS to reduce calls.
For example:
{% cache for 1 day %}
{% set tweets = craft.tweetfeed.tweets(3,'author_id,context_annotations','&exclude=retweets,replies&user.fields=id') %}
{% for tweet in tweets %}
<div>
<h3>{{ tweet.text }}</h3>
</div>
{% endfor %}
{% endcache %}
Tweet Feed Roadmap
Some updates to do and ideas for potential features:
- GQL support
Brought to you by percipiolondon