Skip to content

A linear question-and-answer quiz to accompany a scavenger hunt. Written in React with TypeScript.

License

Notifications You must be signed in to change notification settings

Jonn3y/react-scavenger-quiz

 
 

Repository files navigation

react-scavenger-hunt

react-scavenger-hunt is a small React SPA written in TypeScript that displays an interactive, linear quiz intended to be used during (something akin to) a birthday present scavenger hunt. You can pull down this repo, write your own questions and answers, and use it yourself!

Quiz template screenshot

In action:

Recording

Features

  • Scalable to any number of questions
  • Questions can accept more than one valid answer
  • Full JSX support for rich, dynamic question content
  • Progress saved in browser, so you can leave and resume where you left off
  • Responsive, works great in a phone browser
  • Fully open source and modifiable — tweak it exactly how you want it

Origin

I built this little quiz app in the first month of COVID-19 lockdown as a present for my partner and a way to keep in practice with React while I was looking for a new job. I've stripped the personal stuff from this repo and generalized it so anyone familiar with JSX can use it to make their own quiz.

Here's how the original quiz looked:

Original quiz screenshot

Getting started

First, clone this repo to a machine with NodeJS and NPM installed. Then, in the repo directory:

$ npm i -g yarn
$ yarn

There shouldn't be much limitation re: Node/Yarn version, but this was developed against Node 12.

Creating your own quiz

It's pretty easy to get started making your own quiz. I’d follow these steps:

  1. Edit src/data/QuizData.tsx, which contains the questions and answers for your quiz. Read through the ones already there, since they explain the supported features for question authoring.
    1. You can also change the emojis that cycle through on the start button by modifying the START_BUTTON_EMOJIS array in this file.
  2. The main Animoji image in the middle of the header can be swapped by replacing the images in public/images. I used my partner's Memoji.
  3. Change the <title> to a custom message, if you want.

Develop & build

The project is based on create-react-app, so the build toolchain should be familiar if you've used that before.

Develop locally

$ yarn start

This spawns a server at localhost:3000 with hot module reloading.

Build for production

$ yarn build

Built assets are written to the build directory. Point a static file server like serve to that directory and you're good to go.

Docker

starting a container

In order to use this project inside a docker container, just do:

docker build -t react-scavenger-quiz .
docker run -d --name react-scavenger-quiz -p 3000:80 react-scavenger-quiz

Now you can access the quiz at http://<ip-of-docker-server>:3000/

stopping a container

You can stop the container by running:

docker stop react-scavenger-quiz

deleting the outdated container

In order to start a new container after rebuilding the image, you might need to delete the old container first:

docker container rm react-scavenger-quiz

now you can start a new container with the same friendly name --name react-scavenger-quiz:

docker run -d --name react-scavenger-quiz -p 3000:80 react-scavenger-quiz

About

A linear question-and-answer quiz to accompany a scavenger hunt. Written in React with TypeScript.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 55.9%
  • JavaScript 25.2%
  • SCSS 16.4%
  • HTML 1.8%
  • Dockerfile 0.7%