/vue-spotify

💿 A Spotify web client built with Loopback, Vue, and Vuetify

Primary LanguageJavaScriptMIT LicenseMIT

Vue Spotify Client

A Spotify client web app with some features missing from the official Spotify apps on the roadmap. Demo

Motivation

The ability to shuffle all the tracks in a playlist folder was removed from the Spotify mobile apps, and that was a feature I used frequently. I started this project primarily to get that functionality back on my mobile phone.

Unfortunately the Spotify Web API does not currently expose any information about playlist folders, so until there's an API change to resolve this issue, we've decided to build a custom folder hierarchy stored in the application's database.

Code style

This project uses JavaScript Standard Style, enforced (so far only in the front end) by ESLint.

Use of ES6+ features in this project is encouraged.

Screenshots

Screenshot Screenshot
screenshot screenshot

Tech/framework used

Features

  • Control Spotify from a web interface and play tracks in desktop browsers
  • Build folders shuffle all playlists in them

Roadmap

  • Export all your playlists to JSON
  • Find official music videos on YouTube for playlists
  • Integrate Chromecast for YouTube videos

Prequisites

  • MongoDB
  • NodeJS
  • PM2 (for production deployment)

Installation

Clone the repository

git clone https://github.com/alexanderpepper/vue-spotify.git;

Install NPM packages

cd spotify-utils
npm install
cd client
npm install

Configuration

Configure Spotify App

  1. Create a new Spotify app in the Spotify Developer Dashboard
  2. Note your Client ID and Client Secret
  3. Click "Edit Settings" and add http://localhost:8080/callback to the Redirect URIs

Configure Application

  • Create /server/constants/credentials.js with the following content:
const isProd = process.env.NODE_ENV === 'production'
module.exports = {
  clientSecret: '<your_client_secret>',
  clientId: '<your_client_id>',
  redirectUri: isProd ? 'https://yoursite.com/callback' : 'http://localhost:8080/callback'
}

Development

Running the server and client as separate processes gives the best development experience with hot reloading in the client app.

The client app is

  • Configured in client/config/dev.env.js to use http://localhost:3000/api as the base API path when running in development
  • Configured in client/config/prod.env.js to use /api as the base API path when built for production

Running the Server in Development

To run the Loopback server in devepment mode on https://localhost:3000:

node .

Loopback uses swagger to document the server's REST API. This can be viewed at http://localhost:3000/explorer

Running the Client in Development

To run the Vue client in development mode on http://localhost:8080

cd client
npm run dev

Preparing for Deployment

Acquire a standalone certificate from LetsEncrypt and create server/ssl-config.js with the following content:

const path = require('path')
const fs = require('fs')
const isProd = process.env.NODE_ENV === 'production'

exports.privateKey = isProd ? fs.readFileSync(path.join('/path/to/privkey.pem')).toString() : ''
exports.certificate = isProd ? fs.readFileSync(path.join('/path/to/cert.pem')).toString() : ''
exports.chain = isProd ? fs.readFileSync(path.join('/path/to/chain.pem')).toString() : ''
exports.fullchain = isProd ? fs.readFileSync(path.join('/path/to/fullchain.pem')).toString() : ''

Deploying for Production

When the server starts, /server/boot/client.js builds the client app by running npm run build in the client folder.

To start the server

node_modules/pm2/bin/pm2 start pm2.json --env production

To stop the server

node_modules/pm2/bin/pm2 kill

To monitor the server

node_modules/pm2/bin/pm2 monit

License

MIT © 2018 Alex Pepper