Welcome to the BruinMeet team!
We're super excited to have you on board as a developer and can't wait to see what amazing things we'll build together.
Introduction
First and foremost, if you haven't done so already, perform all the onboarding steps outlined on the main BruinMeet
project repository's README.
This gist will serve as an onboarding guide/tutorial for the front-end side of our tech stack. BruinMeet's front-end is written using the following technologies:
All four of these technologies support our fundamental mission to build a codebase that is
- highly component-based
- reliable
- modular
This Medium article written by @bibekg describes how these technologies fit together to achieve this mission.
Prerequisites
- basic web development knowledge (HTML/CSS/JS)
- basic knowledge of React
- If you are coming in without any experience in React, go through the "Quick Start" section on the (super helpful) React docs, then come back and do this tutorial.
- If you are coming in with React experience, this guide will give you a clear idea of how the other technologies listed above are used along with React.
What This Tutorial Will Cover
- How to write a basic React component that renders differently based on props
- How to write styled components that can adapt to props
- How to write FlowType annotations, particularly for React components
What This Tutorial Will NOT Cover
- How to connect a React component to a Redux store
- Unfortunately, this requires a fair amount of overhead work for such a simple tutorial so it'd be a better use of your time to read through the React-Redux docs, do tutorials online, read through the existing bm-web codebase, and ask other team members about areas that you find confusing.
Okay, so what am I gonna build for this tutorial?
For this tutorial, you are going to create two key components that exist on the BruinMeet website already, Button
, and LogInButton
.
First, start by digging around the entire src/
folder. There are three files you will need to modify as part of this tutorial, App.js
, Button.js
, and LogInButton.js
.
In App.js
, all you have to do is uncomment the two lines that render Button
and LogInButton
after you write each of those components.
In the latter two files, you will create two React components.
Note that the requirements for these components have been slightly simplified for this tutorial. After you're done, check out how the components are actually implemented in bm-web/src/js/components
.
Button
A general-purpose button component that is used across the codebase wherever a button is needed.
Requirements
- is written in
src/js/components/Button.js
- includes the Flow comment flag at the top of the file
- the default export of the file is a Styled Component
- the button has two styles that can be controlled by the props passed in to the component
- the Edit button is the "primary" style
- the Deactivate button is the "secondary" style
- don't spend too much time trying to make the style match the below image perfectly; the main point of this exercise is to make sure you understand how to adapt the component's styles based on props
- How do I adjust styles based on the props?
This is how the Button component should look. The Edit button has the "primary" style and the Deactivate button has the default "secondary" style.
This is how you should be able to use the Button component.
<Button primary>Edit</Button> // renders a primary-styled button
<Button>Deactivate</Button> // renders a secondary-styled button
LogInButton
A button that renders either "Log In", "Log Out", or "Sign Up Now" and processes the action when the user clicks on it. Composed of the Button
component from above.
Requirements
-
is written in
src/js/components/LogInButton.js
-
the default export is a React component that renders a primary-styled
Button
-
Provide the following props for the component
isLoggedIn
-- a required boolean; this is usually a prop that we don't need to provide while using<LogInButton />
because it is injected by Redux. This tutorial doesn't cover Redux so we'll treat it as an actual prop to be used like<LogInButton isLoggedIn={true} />
.override
-- an optional string that can be eitherlogin
,logout
, orsignup
- This prop can be used to override the behavior of the button instead of letting the button determine what to render and do when clicked based on
isLoggedIn
- This prop can be used to override the behavior of the button instead of letting the button determine what to render and do when clicked based on
-
Provide FlowType annotations.
-
Adjust the button text based on the value of
props.isLoggedIn
- If
props.override
is provided, show the corresponding text - If it is not provided,
- If
props.isLoggedIn
is true, show "Log Out" - If it's false, show "Log In"
- If
- If
-
On click of the button,
window.alert(message)
to display a custom message.- If
props.override
is provided, alert a message based on its value - If it is not provided,
- If
props.isLoggedIn
is true, alert "Logging you out..." - If it's false, show "Logging you in..."
- If
- If
I'm done, what do I do now?
Good work! 😄 Here are the next steps.
- Verify that your solution works for all cases (e.g. both values of
isLoggedIn
and all three values ofoverride
) - Compare your solution with the solution in
SOLUTIONS.md
. If you have any questions, ask them on the #dev channel on Slack. - Upload your completed project to GitHub and send the repo link to the #dev channel.
Someone will then review your code and get back to you asap about moving forward.