If you want to share your love for music with the world you are in the right place. Show what's playing on your Spotify by posting the generated image!
πΈ playing now - current state of the playing track with real-time progress bar
π¬ ended state β when a track is ended, the badge transitions to this state
βΈ paused state - when the current track is paused in the player
π idle state β not playing
- Go to Spotify Developer Dashboard and log in with your Spotify account
- Click Create An App
- Fill in the name and description of a new app and click Create.
- Click Show Client Secret.
- Copy Client ID and Client Secret we will need it a bit later.
- Open this link for deploy app to Vercel
- Click Continue on Clone Git Repository screen
- Choose where you want to save code on Create Git Repository and Vercel will fork this repo automatically
- Click Continue on Import Project screen
- Put Client ID to
SPOTIFY_CLIENT_ID
and Client Secret toSPOTIFY_CLIENT_SECRET
and put just-
toSPOTIFY_REFRESH_TOKEN
. - If you plan to use API specify
API_CORS_HOST
as the host from which you plan to call the API endpoint. Read more - Click Deploy
- When an application is deployed go to Dashboard
- Copy your domain with
prod
label of your application - Go back to Spotify Developer Dashboard
- Open application
- Click to Edit Settings
- Add path
/api/auth
to the deployment domain. It should look like thishttps://spotify-badge-c74hazo6k-akellbl4.vercel.app/api/auth
. Screenshot - Put the url Redirect URI and click Add
- Save changes by clicking on Save at the end of the form
- Open a new tab on the browser and go to the url which you put in Redirect URI. The URL should look like this
https://spotify-badge-c74hazo6k-akellbl4.vercel.app.akellbl4.vercel.app/api/auth
- Copy Refresh token and put to the application settings on Vercel
- Go to the Deployments page and redeploy the last deployment of your application on Vercel
- Everything is done!
You can copy this snippet and change the domain in the URL to the domain of your application and post it wherever you would like
<img
src="https://spotify-playing-now-readme.vercel.app/api/now-playing.svg"
width="540"
height="52"
/>
To make API available, specify API_CORS_HOST
after you deploy the app.
- Open the created project on Vercel and go to Settings.
- Open tab Environment Variables
- Create a variable with the name
API_CORS_HOST
and put the site address from which you plan to make requests for examplehttps://example.com
(the variable will be set toAccess-Control-Allow-Origin
header. More about the header)
Response:
When something is playing
type Response =
/** When a track is playing */
{
progress: number | null;
duration: number;
track: string;
artist: string;
isPlaying: boolean;
coverUrl: string;
url: string;
}
/** When nothing is playing */
| {
isPlaying: false;
}
- Copy
.env.example
to.env
and add values to env variables - Run
pnpm install
for dependencies installation - Run
pnpm dev
to start a development server