Skip to content

Latest commit

 

History

History
104 lines (64 loc) · 5.2 KB

README.md

File metadata and controls

104 lines (64 loc) · 5.2 KB

The Legacy Project App

Welcome to The Legacy Project's JumboCode team! This is our repository where we will keep our code and track changes.

Setup

This section will walk you through the steps to set up your laptop for development. Please reach out to us if you're stucked or confused at any point!

Terminal

Open the command line interface for your Operating System. On Windows, we recommend using Windows Linux Subsystem; on Macs, you can proceed with Terminal.

Version Control

Git

We will use Git for version control. After you have opened the terminal, verify that Git is installed on your machine

# Terminal
# "which" command locates an executable called "git"
which git

If which git raises an error, then you will need to install Git.

GitHub

We will use Git to interact with GitHub, a code hosting platform. We will now set up your terminal to work with GitHub.

  1. Create a GitHub account if you do not have one.
  2. On terminal, set up your identity.
# Terminal
git config --global user.name <Your GitHub username>
git config --global user.email  <Your GitHub email>
  1. Create a SSH key to interact with GitHub, following this guide. Once you have created your SSH key, go ahead and add it to your GitHub account, as instructed here.

Application Dependencies

We will need to install Node.js to run JavaScript for development - you can check whether Node.js is installed by typing which node on the terminal.

Editor

We will use Visual Studio Code to write code. After you have opened Visual Studio Code, we will install some productivity extensions:

  1. ESLint - A static analysis tool for JavaScript applications,
  2. Prettier - A tool to automatically format code,
  3. Prisma - Syntax highlighting for Prisma schemas,
  4. Tailwind IntelliSense - A tool to improve development with TailWind.

Acquiring the code

In your terminal, navigate to the folder where you want Git to put your TheLegacyProject2 folder containing the source code. To pull the code, run the following command:

# Terminal
git clone [email protected]:JumboCode/TheLegacyProject2.git

If the command did not error out, you can now navigate to a folder named TheLegacyProject2.

Environment Variables

We will need credentials to connect with external services, such as MongoDB. It is bad security practice to commit these credentials to the codebase. Create a .env directly under the root directory; this file does not already exist, but there is a .env-example for you to copy over. Finally, talk to us to get the credentials.

Running The Application

On terminal, type:

  1. npm install to install all the necessary packages to run the application,
  2. npm dev to start development server.

If the commands did not error out, then congrats! You've successfully started the server and are ready to make some changes 😁. You can visit http://localhost:3000/ to view the website.

Development

This section outlines some guidelines and expectations for development.

Making Changes

We prefer small and iterative changes, as they will be easier to review. To start developing a new feature, the general development process is as follow:

  1. git checkout main
  2. git checkout -b <Your GitHub username>/<feature>
  3. Make your changes
  4. Once you're happy with your changes:
    1. Make sure that npm run build doesn't error out,
    2. git add <file 1> <file 2> ... <file n> to stage all the files you want to commit for version control,
    3. git commit -m "<A message to describe your changes>",
  5. Go to the GitHub repository to make a Pull Request (PR). After you've made a PR, request for review from someone else.

Resources / Additional Information

Git

Git can be especially confusing if this is your first time using it. We recommend that you read through the first 3 chapters of Git Book.

Next.js

You may have noticed that we have 2 different folders with frontend code: src/pages/ and src/app/. The first folder contain code that was developed by the Jumbo Code group last year, which uses Next.js 12. We will mostly work with src/app folder, which uses Next.js 13. Therefore, when you're searching online for documentations, be sure to look at the correct Next.js version for your use case.