/sidebar-chat

Gatherly's take-home technical assessment

Primary LanguageJavaScript

Engineering Challenge

Sidebar 📺 💬

Our main app is an immersive virtual space where users can sporadically form huddles, hear broadcasts, and get the "public gathering" feel of an in-person event from the comfort of their personal computer.

But just for fun, what if we wanted to have a sister app that delivers a simpler, more intimate video chat experience? Sidebar Chat is the result.

To be honest, it could use a little work... Maybe you can help?

Directions

  1. Click the "Use this Template" button to generate a new PRIVATE repo from this one.
  2. Run it locally using the instructions below. (If you are having trouble, feel free to reach out to alicia@gatherly.io or your point of contact.)
  3. Whip it into shape. Using the basic functionality checklist below, as well as your general knowledge of coding best practices and app development, identify and fix as many problems as you can.
  4. Invite your interviewers, as listed in the prompt email.

A successful video chat app will:

  • Allow anyone to create a virtual video chat room
  • Allow up to 3 other people to join their video conversation via a link
  • Show video tiles for all present attendees
  • Allow users to and mute/unmute themselves
  • Allow users to turn their camera on & off
  • Display users' names and pronouns whether their video is on or off
  • Allow the host to end the conversation
  • Comply with basic accessibility standards

Additional Directions for Senior Engineers

Kick it up a notch by adding one (1) additional feature that you think will take this app to the next level. What you choose to add is up to you, but you should pick something that can be accomplished within the allotted time (3-5 hours for the entire challenge), will significantly improve user (or possibly developer) experience, and will show off your unique skillset.

Some ideas for inspiration...

  • Make the app work well on mobile devices
  • Allow attendees to share their screen
  • Allow the host to choose a chatroom color scheme when creating their chatroom
  • Creating a super-plush build process that deploys the app somewhere on the internet,

Local Development

Environment Variables

Note: the configuration of environment variables assumes a UNIX Operating system. If you are using Windows, you will need to employ cross-env or another solution for making environment variables accessible to the apps.

.env

ENVIRONMENT=development
AWS_ACCESS_KEY=<your_aws_key>
AWS_SECRET_KEY=<your_aws_secret_key>
PORT=3030

/side-bar-web/.env.development

REACT_APP_HOST=http://localhost:3030

Database

This project uses SQLite3 database for ease of local development.

Server

npm install
npm run start

Server will be running on localhost:3030.

Client

cd side-bar-web
source .env.development
npm install
npm run start

Navigate to http://localhost:3000/ to view the app.

Note: The current distribution of the node-sass package can fail to compile properly in some environments. The "install-with-rebuild" script runs an extra npm rebuild node-sass to avoid build issues.