Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rathna-git/musilink
A web app for visualizing personalized Spotify data built with React, Node, Express, and the Spotify API
https://github.com/rathna-git/musilink
express javascript nodejs react react-hooks react-router rest-api spotify-api styled-components
Last synced: 16 days ago
JSON representation
A web app for visualizing personalized Spotify data built with React, Node, Express, and the Spotify API
- Host: GitHub
- URL: https://github.com/rathna-git/musilink
- Owner: rathna-git
- License: mit
- Created: 2023-10-12T02:34:04.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-18T19:28:56.000Z (about 1 year ago)
- Last Synced: 2024-11-04T00:02:51.234Z (2 months ago)
- Topics: express, javascript, nodejs, react, react-hooks, react-router, rest-api, spotify-api, styled-components
- Language: JavaScript
- Homepage:
- Size: 6.99 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MusiLink
A web app for visualizing personalized Spotify data. View your top artists, top tracks, recently played tracks, and detailed audio information about each track.
### Don't forget ⭐ the repo!
## Tech Stack
### Frontend:
JavaScript, React with Hooks, Styled Components
### Backend:
Nodejs, Express.Deployed @ Heroku
## Demo
### Login and Profile Page
User login page using Spotify OAuth. On successful login it then displays the user's profile page.
https://github.com/rathna-git/MusiLink/assets/16769143/571b7dff-ba66-4044-94c0-620fd63b03f3
### Top Artists Page
Displays the top artists the user listened to this month and in the last 6 months and all time.
https://github.com/rathna-git/MusiLink/assets/16769143/955f8095-32c6-4ced-a81b-fc84ab5b0382
### Top Tracks Page
Displays the top tracks the user listened to this month and in the last 6 months and all time.
https://github.com/rathna-git/MusiLink/assets/16769143/05f8a44d-e7fe-4a31-a56f-f91417ae0365
### Playlists and Playlist Pages
Display user's playlists and tracks in that playlist. User can sort the tracks based on dancebility, tempo and energy levels.
https://github.com/rathna-git/MusiLink/assets/16769143/d1922939-67aa-45f2-983e-f552fe017b83
## Local Installation & Set Up
1. Fetch latest source code from the main branch.
```shell
https://github.com/rathna-git/MusiLink.git
```
2. Register a Spotify App in your [Spotify Developer Dashboard](https://developer.spotify.com/dashboard/) and add `http://localhost:8888/callback` as a Redirect URI in the app settings3. Create a `.env` file at the root of the project based on `.env.example` and add your unique `CLIENT_ID` and `CLIENT_SECRET` from the Spotify dashboard
4. Ensure [nvm](https://github.com/nvm-sh/nvm) and [npm](https://www.npmjs.com/) are installed globally
5. Install the correct version of Node
```shell
nvm install
```6. Install dependencies
```shell
npm install
```7. Run the React app on and the Node server on
```shell
npm start
```## Deploying to Heroku with Git
1. Create a [Heroku](https://www.heroku.com/) app
2. Add your Heroku app as a git remote
```shell
heroku git:remote -a your-app-name
```3. Add `http://your-app-name.herokuapp.com/callback` as a Redirect URI in your Spotify app's settings
4. In your app's **Settings** tab in the Heroku dashboard, add [config vars](https://devcenter.heroku.com/articles/config-vars#using-the-heroku-dashboard).
Based on the values in your `.env` file, the `CLIENT_ID`, `CLIENT_SECRET`, `REDIRECT_URI`, and `FRONTEND_URI` key value pairs. Make sure to replace the `localhost` URLs with your heroku app's URL.
```env
REDIRECT_URI: http://your-app-name.herokuapp.com/callback
FRONTEND_URI: http://your-app-name.herokuapp.com
```5. Push to Heroku
```shell
git push heroku main
```
## CreditsInspired by Spotify Profile page.
## License
Musilink is developed under the [MIT license]