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!
Google Font - Open Sans
Google Font - Alegreya
- User can login into their account.
- User can register for an account.
- User should be navigated to the Browsing View on a successful login or successful registration.
- User can view all items available for purchase
- User can filter books by meal
- User can reset an applied filter to see a list of all items again
- User can navigate to Item Details View by clicking on the items in the list
- User can navigate to Add Item View
- User can logout and be redirected back to the Auth View
- User is able to add item to cart from here
- User is able to navigate to Edit Item View
- User is able to delete a item from the database
- This should redirect the user back to the Browsing View
- User is able to navigate to previous view
- User should be redirected to the Browsing View after adding the item to the cart
- User populates an editable section based on the selected item's details to update and change information about the item
- User is able to navigate to previous view, canceling the edit
- User should be redirected to the Browsing View on completion
- User can add a new item to the menu with all the appropriate values
- Name, Price, and Description
- User is able to navigate to previous view, canceling the addition of a new item
- User should be redirected to the Browsing View on completion
- User is able to remove an item from cart and cart is updated
- User can checkout
- Thi should clear the cart
- User should be redirected to the Browsing View on checkout
- 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
- 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.