/fe-code-challenge

Primary LanguageJavaScriptOtherNOASSERTION

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.

  1. Download or clone this repository.
  2. Run nvm use (or if not using nvm an equivalent command to set your node version to 12)
  3. Run npm install to download all necessary dependencies.
  4. Run npm start to serve the API (see API notes below) and spin up the local development environment.
  5. Implement your solution.
  6. 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 by id.
  • GET /reservations/:id - Get a reservation by id
  • 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