Unify is a visually captivating platform designed for Spotify users to dive into their listening history and compare music habits with friends. Unify brings a unique perspective to your music exploration by offering insights into how closely your tastes align with others.
- Visual Exploration: Navigate through your Spotify listening history in a visually engaging way.
- Comparison Tools: Compare your music habits with others to discover similarities and differences.
- Shareable Visualizations: Generate and share Y2K-style graphics that represent your music tastes and listening habits.
- Deep Insights: View detailed statistics like diversity of your music, uniqueness of your tastes, and match rankings with friends.
- Social Integration: Easily share your music insights with friends and on social media.
Unify aims to enhance your music experience by making it more interactive and visually appealing. It strives to create a platform where you can explore your musical identity, compare it with others, and enjoy custom content tailored to your tastes.
You need Node.js installed. The project currently supports Node v20.12.2 but will likely work with other Node versions.
npm install
This project requires Supabase in order to run. Inside the .env
file, there exists the two Supabase keys required to run the application, NEXT_PUBLIC_SUPABASE_URL
and NEXT_PUBLIC_SUPABASE_ANON_KEY
. The current values are tied to an existing Supabase project (and because these are public, client-exposed keys to a Supabase database protected with RLS, these two keys are safely tracked in Git). To connect the application with your own Supabase project instance:
-
Create an account at Supabase.
-
Follow the steps here to connect Supabase with Spotify: [https://supabase.com/docs/guides/auth/social-login/auth-spotify].
-
Go to the SQL Editor page in the Supabase Dashboard. Click User Management Starter. Click Run. This step is from a tutorial here.
-
Optional - Update the email confirmation template in Supabase:
-
Go to Authentication > URL Configuration
-
Change the Email Template link to:
<p><a href="{{ .ConfirmationURL }}">Confirm your mail</a></p>
-
-
In
.env
in the root directory, change the values forNEXT_PUBLIC_SUPABASE_URL
andNEXT_PUBLIC_SUPABASE_ANON_KEY
.
To start the application, simply run npm run dev
. You can access the application from localhost:3000
.
File/Folder | Description |
---|---|
__tests__/ |
Jest tests. |
.github/ |
Github Action scripts. |
.husky/ |
Pre-commit hooks, as described in Git Strategy. |
src/ |
Main code files. |
.all-contributorsrc |
See https://allcontributors.org. |
.env |
Non-secret environment variables. |
jsconfig.json |
VS Code IntelliSense support file. |
Other supporting files in the root directory include configuration files for linting (ESLint + Prettier), testing (Jest), Next.js, and others.
File/Folder | Description |
---|---|
app/ |
Main page files, following the Next.js app routing system. |
shared/ |
Components shared across multiple pages. |
utils/ |
Various backend utility functions, primarily Supabase authentication scripts. |
fonts.js |
Optimized font face exports. |
middleware.js |
Used for Supabase authentication. |
spotify.js |
Backend used for communicating with Spotify API. |
- Pre-commit Hooks: There is a pre-commit hook that lints the code files using ESLint and Prettier. This is done via the
lint-staged
package and configured inpackage.json
. - Protected Branches: There are two protected branches,
master
anddev
. Both branches cannot have direct commits; instead, a pull request must be opened and approved by another contributor. - Branches & Pull Requests: Contributors create a new branch specific to a feature. There is no branch naming convention. Once the feature is finished,
dev
is merged into the feature branch, and a new PR is opened to merge the feature branch intodev
. Another contributor must approve the PR before it can be merged. Ideally, it should pass the Github Action test scripts as well. - CI/CD & Github Actions: There are two Github Action scripts that get triggered upon a new pull request. The first is a test script that essentially runs
npm test
. The second is a lint script that checks for linting errors and warnings. Fordev
, all ESLint errors must be resolved for the test to pass. Formaster
, all ESLint errors AND warnings must be resolved for the test to pass. Vercel also runs two integrated Github Action test scripts after a new pull request is created to check for Vercel preview deployment issues. - Vercel: Vercel creates a new preview deployment after a new pull request is created. Vercel creates a new production deployment after a pull request is merged into the master branch.
To test the application (run all tests):
npm test
To run a specific test:
npm test testName
We have achieved 89% statement coverage.
To add a test, add a file to __tests__/
with the file extension .t.js
. This file will contain the tests themselves, and we are using Jest for testing — so any correctly formatted Jest test will work.
In terms of specific backend tests, examples can be found in get_spotify_data.t.js
. Using Jest, this file shows how one can mock a backend call to ensure that the correct number of calls are made with the needed requirements.
To lint the application:
npm run lint
Note that the code must fully pass npm run lint:prod
before being able to be merged into master
.
The application is currently deployed via Vercel at http://unify-cs439.vercel.app.
NOTE: To create an account in the existing deployment, you must be a registered user in our Spotify API application, as the application is currently in development mode (on Spotify's end). Contact david.crair@yale.edu to be added as a user.
You can view an example of a User Profile page at http://unify-cs439.vercel.app/user/testuser. You can view an example of a Unify Results page at http://unify-cs439.vercel.app/unify/testuser&hoixw.