Giter VIP home page Giter VIP logo

simulation-music's Introduction

Project Summary

This project is designed to replicate what you might receive on the job. There won't be any guided instruction on what you'll need to do. We will only provide you with design specifications and technical requirements. Your mentors have also been asked to provide only minimal guidance. They can point you in the right direction, but cannot help you code. This project is a chance for you to combine and showcase the skills you've learned so far.

With this specification/requirement only structure, we believe this project will showcase what you can do at this point of the program. Because of this, we feel this project will be worth putting in your portfolio.

Good luck and work hard!

Color Palette & Font

Google Font - Open Sans

The icons are included in the assets folder of this repository

Application Design

Auth View

All Songs View

Song Details View

Playlist View

All Playlists View

Add Song View

Edit Song View

Technical Requirements - Front-end

Auth View

  • User can log in into their account.
  • User can register for an account.
  • User should be navigated to the All Songs view on a successful login or successful registration.

All Songs View

  • User can view All Songs available for checkout
  • User can filter songs by name / artist / album
  • User can reset an applied filter to see a list of All Songs again
  • User can navigate to Song Details view by clicking on a song in the list
  • User can navigate to Add Song view through link in top corner
  • User can log out and be redirected back to the Auth View

Details View

  • User is able to add song to playlist from here
  • User is able to navigate to Edit Song view
  • User is able to delete a song from the database
    • This should redirect the user back to the All Songs View
  • User is able to navigate to previous view
  • User should be redirected to the All Songs view after adding the song to the playlist

Checkout / Playlist View

  • User is able to remove a song from playlist and playlist is updated in header and component
  • User can check out
    • Should add the songs in the playlist to an order on the past orders page
    • Should clear the Playlist View
  • User should be redirected to the All Songs view on checkout

All Playlists View

  • User can see all playlists

Add Song View

  • User can add a song to the All Songs view with all the appropriate values
    • Name
    • Artist
    • Album
  • User is able to navigate to previous view, canceling the addition of a new song
  • User should be redirected to the All Songs view on completion

Edit Song View

  • User populates an editable section based on the selected song's details to update and change information about the song
  • User is able to navigate to previous view, canceling the edit
  • User should be redirected to the All Songs view on completion

Technical Requirements - Back end

  • The back end should be created using Express.
  • Massive will be used to establish a connection to your database and manipulate/retrieve data with SQL files
  • Student will create tables using the supplied data

Endpoints

Authorization Endpoints

  • POST - /api/auth/login - Sets the user information on the session.
    • On success return a status of 200 and the user object.
    • A user object should have the following properties:
      • id - This is the UserId you are using for your database.
      • username - This is the username associated with the UserId.
    • The database should store the password, but you should not send this information to the front end as part of the user object
    • On failure return a status of 500.
  • POST - /api/auth/register - Registers a user to the database. Sets the user information on the session.
    • On success return a status of 200 and the user object.
    • A user object should have the following properties:
      • id - This is the UserId you are using for your database.
      • username - This is the username associated with the UserId.
    • The database should store the password, but you should not send this information to the front end as part of the user object
    • On failure return a status of 500.
  • POST - /api/auth/logout - Destroys the session. Sends a status of 200.

NOTE: This is in no way a secure or effective way of storing user credentials. This is required for you to demonstrate your knowledge of data transfer and correspondence between the user and your server using sessions. Do not ever rely on this method in anything bound for production.

Contributions

If you see a problem or a typo, please fork, make the necessary changes, and create a pull request so we can review your changes and merge them into the master repo and branch.

Copyright

© DevMountain LLC, 2017. Unauthorized use and/or duplication of this material without express and written permission from DevMountain, LLC is strictly prohibited. Excerpts and links may be used, provided that full and clear credit is given to DevMountain with appropriate and specific direction to the original content.

simulation-music's People

Contributors

alan-miller avatar devlemire avatar

Stargazers

 avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.