/citrushack2023

Codebase for CitrusHack 2023.

Primary LanguageTypeScript

Citrus Hack 2023

Author: Minsoo Kim

This is the codebase for Citrus Hack 2023. Below is a short project description and a guide for setting up a local environment to run the project locally for development purposes

Leads

Minsoo Kim

image of Minsoo Kim

Hey I'm Minsoo! I'm a software engineer based in California. I like to weightlift or boulder after a long day of coding :) You can connect with me on LinkedIn or my Github.


Paulian Le

image of Paulian Le

Hello hello! I'm Paulian. I'm a software engineer based in Southern California. In my free time, I love to boulder and to watch movies. My favorite film has to be "La La Land" at the moment. :) 🎵 Feel free to connect with me on my LinkedIn. Cheers!



Tech Stack

Next JS Vercel Typescript

TailwindCSS HTML5 CSS3

MongoDB Firebase

cypress ESLint Prettier GitHub Actions

Figma

Prerequisites

Windows

  • Windows Terminal: This is used to navigate through the project/repo and to run the development server.
  • Ubuntu WSL (Recommended): This is to use the bash terminal found in Linux. I recommend using a WSL to use Linux commands for developing this project. Follow this guide to install

All OSes

  • Install Git
  • Install Node.JS
  • Install Yarn
    • Run the following command to install: npm install --global yarn
  • Install a code editor of your choice (e.g VScode, Atom, Sublime, etc.)
  • Install at least two popular browsers (e.g. Chrome, Firefox, Safari, etc.). This is for testing for cross compatibility for different browsers

Setting Up Your Local Environment

Run the following commands in a terminal

Forking

Forking the repo to work on your own code

  • Fork the repo by clicking the Fork button in the upper right corner
    • This creates a copy of the repository in your own account

Clone the Project

  • git clone <forked_repo_link>
  • cd citrushack2023
    • This is to navigate into the directory generated for the cloned repo
  • If you are using VScode, run code . to open the current directory in VScode (this is mainly for easier navigation)
    • You may need to install code so run sudo apt install code

Install Necessary Packages

  • yarn or yarn install
    • This will install all necessary packages for the project

Run the Development Server

  • yarn dev
  • Go to http://localhost:3000/
    • This is the port where the development server is run on. Any changes you make to the code will reflect almost instantly while the server is running

Contributing to the Project

Creating Branches

  • Create your feature branch from the main branch: git branch <github-username>/<feature-description>
    • The feature branch should only deal with one issue
    • Make sure to create multiple branches for multiple issues, each with its own issue
      • We don't encourage working on more than 2 issues at a time
  • git checkout <github-username>/<feature-description>
  • Make sure you are on the feature branch: git branch
  • Never work on the main branch

Committing Changes

  • Check what files you edited: git status
  • Adding files to commit: git add <file-name> or git add . to commit all files
  • Commit files: git commit -m <useful-message>
    • Try committing frequently and writing useful messages to describe the changes you made
  • Push your changes: git push
    • If it's your first time pushing changes from a new branch, you may need to run git push -u origin <branch-name>

Creating Pull Requests

Make a pull request when you have code to merge

  • Go to your forked repo on Github and click the "Contribute" option near the top
    • Click Open Pull Request
    • Compare your branch to the main branch. Then click Create Pull Request
    • Assign the webdev lead to review your code (see the righthand side)
    • NEVER merge your own PR! (PR is short for Pull Requests)
    • Leave a comment if you want to. Then click Create Pull Request

Reviewing Pull Requests

  • Code reviews are just as important as the code itself
  • Head over to the Pull Requests tab and review the changes
    • Leave comments if you have questions/suggestions/concerns
  • DON'T merge the code even after you have reviewed the code
    • One of the web dev lead will do a final review and do the merging

Fetching Upstream

Match your repository to the master branch

  • Go to your forked repo on Github and click the "Fetch upstream" option near the top
  • Click Fetch and Merge to fetch the master branch and merge the master code into your repo
    • This will merge any new changes made in the master branch into your repo
    • I recommend committing any of your changes to your forked repo before doing this, so you can see if there will be any conflicts

Assigning Yourself to Issues

Issues are tasks to be done for the project

  • Go to the repo on Github and open the "Issues" tab
    • This acts as a taskboard for what needs to be done for the project
  • Click on an issue to read more information about it
  • If you want to work on an issue, assign yourself to the issue (see the righthand side)