Fetch data in real time from Spotify APIs.
This guide demonstrates how to retrieve data from the Spotify API (such as currently playing track) in a react application or server component.
npm i spotify-connect
-
Get currently playing track: Retrieve information about the track currently being played by a Spotify user.
-
Get recently played tracks: Retrieve the list of recently played tracks of a Spotify user.
To get started, you'll need the following:
- client_id: Spotify app client ID
- client_secret: Spotify app client secret
- refresh_token: Spotify app refresh token. You can generate one as explained in various articles on the web. Example
The response from the Spotify API can be parsed using the following method:
parseCurrentTrack(data)
Returns:
{
track: {
id: item.id,
name: item.name,
artist: item.artists,
album: item.album.name,
image: item.album.images[0].url,
duration: item.duration_ms,
progress: progress_ms,
uri: item.uri,
},
timestamp,
}
- In the root of your application or wherever you want to use spotify-connect utilities, import the
SpotifyConnectContextProvider
.
<SpotifyConnectContextProvider
clientId={SPOTIFY_CLIENT_ID}
clientSecret={SPOTIFY_CLIENT_SECRET}
refreshToken={SPOTIFY_REFRESH_TOKEN}
>
- Now you can use the utility in your component. You can configure when to invalidate stale data and refetch.
const { data } = useCurrentTrack()
options: {
refetchInterval: (milliseconds, default = 5000 or 5seconds)
}