In a world, where there weren't enough fun games, the Gut Busters team set off to build agame that is fun. Like, it's FUN. Seriously. The Quiplash-like game with more a user input —— and therefore more fun!
- React was used to build the User Interface for the app
- Redux states were used for functionality like fetchGame, setGame, and setVote
- Websocket connections used for mobile desktop communication for functions like createGame, joinGame, and submitVote
- SCSS used to style user interfaces
- Figma used for initial mockups and design stages
Read details in the API gitpage at https://github.com/dartmouth-cs52-19S/project-api-gut-busters
- MongoDB as database for the app
- Express.js as server for the app
- Node.js is as our runtime environment for the app
First thing you see is this handy landing page shows three things
- provides an easy accsess QR code for players to join the game
- provides instructions for how to play the game for new players
- a little biography about the creation of the game by our lovley team
{ width=350px }
From the links of the landing page you will be directed to the starting screen for the desktop and mobile pages shown below Click start game whenever!
Have players join the room with the uniquely generated code displayed on the desktop!
Unique code on the upper left corner for players to enter.
Watch the users pop up like magic and click Start Game
when all players have joined
Enter in the room code and a username of your choice! Be creative.....but not too crazy! After you join the game you will see this waiting screen until all other players gave joined and the game has started. Enjoy the ghastly jokes while you're waiting 😉
{ width=200px }
Start playing! Answer the randomly generated questions!
The big screen will have simple instruction in case the intent of answering isn't clear
Quick, quick quick get those answers in before the timer runs out! Feel free to modify your answers if inspiration strikes a little later too!
You and one other player will be answering each question, and the questions are randomly distributed, so don't try cheating off your neighbor!
Battle of the wit begins, vote for the best answer on the screen!
See the options that people are voting on and what your opponent came up with for each question.
{ width=350px }
After each question is voted for, see who pulled ahead of popular opinion with the results screen.
{ width=350px }
Voting begins! May the best answer win! Please know that you are also on a time limit, so make haste.
data:image/s3,"s3://crabby-images/e1f5c/e1f5cbe3ac584d70a286746cca89faf89f1b4051" alt="Vote"
If you are a speedy voter, enjoy another joke while the other voters catch up.
{ width=200px }
If this is your answer, then you can't vote for yourself, that's cheating!
Sit tight while the other players decide your fate.
{ width=200px }
See who came out on top with the final ranking.
Moment of glory or stage of shame, see who had the wittiest, gut-busting answers.
{ width=350px }
How'd you do? Rank number 1, or bottom of the barrel? Either way hope you had fun!
{ width=200px }
🚀 yarn to install and yarn start to run!
!
remember to run both the client side and the server
- Deployed at (frontend) http://gut-busters.surge.sh/ and (backend) http://gut-busters.herokuapp.com/
- See http://gut-busters.surge.sh/desktop for landing desktop page
- See http://gut-busters.surge.sh/mobile for landing mobile page for each player
Have fun playing!
Our team was incredible. We all worked hard despite busy schedules to make meetings happen and work together when we could—especially when it came crunch time towards the final submission deadline!
The scope of the project was much larger than previously anticipated, but breaking down components and using both websockets and redux state made it possible to enact all the functionality we priviously planned.
That being said, we had an backend amazing team that figured out the functionality of websockets and timers which none of us had previous experience with prior to this project.
Creating a game, having semi-original branding, interesting gameplay and different algorithms based on number of players for scoring, answers and questions took a lot of planning and often involved hours not even typing a single line of code, but it did come together and we are so incredibly proud of this project that we’ve created!
While breaking into the front-end and back-end teams was a great way to start the planning and design of the project, we waiting too long to reconvene, which lead to miscommunication when connecting the front and back end. Practicing more partner coding would have helped this issue.
Testing was especially difficult since the need of multiple players to be recognized means testing it locally ran into problems with local storage which we used to keep track of player identity. This mean we had to take a complete compiling and deplyable object to run alot of testing.
Something that was difficult was planning meeting times. Everyone in the group is incredibly involved in so many other things on campus and/or had pre-existing commitments during times that other groups spent a lot of time working.
- Adding make your own question functionalities
- Adding more to the premade database of questions
- Having selectable themed premade databases of quesitons
- Single Player Mode
Charlotte Chui, Stephen Crowe, Madison Hazard, Madeline Hess, Danielle Fang
- https://medium.com/dailyjs/combining-react-with-socket-io-for-real-time-goodness-d26168429a34
- https://itnext.io/how-to-use-a-single-instance-of-socket-io-in-your-react-app-6a4465dcb398
- https://stackoverflow.com/questions/3458553/javascript-passing-parameters-to-a-callback-function
- https://medium.com/dailyjs/combining-react-with-socket-io-for-real-time-goodness-d26168429a34
- https://stackoverflow.com/questions/25500316/sort-a-dictionary-by-value-in-javascript