SpotHero FE Coding Challenge
Complete the two stories below to finalize a fictitious SpotHero checkout flow.
Prerequisites
- node v12 & npm v6
Story #1
Background
Users want to see details about a spot before purchasing it.
Requirements
Implement a modal that shows the spot details. Follow the design provided by the product team.
- The modal should animate in and out gracefully, not just appear/disappear.
Story #2
Background
Users should be able to purchase a spot.
Requirements
Add a form that takes user input, verifies it, submits it to the backend, and allows the user to hit the confirmation page. Follow the design provided by the product team.
- Email and Phone Number fields are required and should display errors if not filled out correctly.
- Phone Number should only allow entry of digits. Bonus points for auto-formating to a US phone number (such as (xxx) xxx-xxxx).
- Adjust the confirmation page (if necessary) to ensure it works and renders correctly.
- Make sure that a second run through the flow and booking another spot updates all UI correctly.
Directions
You may use any additional open source tools you wish to satisfy the requirements.
- Download or clone this repository.
- Run
nvm use
(or if not using nvm an equivalent command to set your node version to 12) - Run
npm install
to download all necessary dependencies. - Run
npm start
to serve the API (see API notes below) and spin up the local development environment. - Implement your solution.
- Package up your project as a zip file and upload it to the relevant location within Greenhouse.
API
The API lives at http://localhost:8001/api
.
Available routes include:
GET /spots
- Get a list of available spots.GET /spots/:id
- Get a spot byid
.GET /reservations/:id
- Get a reservation byid
POST /reservations
- Purchase a spot.{ spotId: int, email: string, phone: string, lastName: string, firstName: string, }
Notes
- Make sure to include all necessary fields for the API request in story #2
- If you are unfamiliar with json-server, it may be worth the time to familiarize yourself with it
- Would anything here make sense to test?
- This repository may have old packages, feel free to upgrade the packages and leave an explanation here in the README explaining your thought process.
- Remember, the devil is in the details