Skip to content

Latest commit

 

History

History
229 lines (164 loc) · 6.16 KB

CONTRIBUTING.md

File metadata and controls

229 lines (164 loc) · 6.16 KB

waterthetrees

Water The Trees is a platform that crowd sources tree planting and maintenance. We believe in the power of trees to restore natural habitat for animals, insects, and fauna. We are interesting in continuous massive tree planting events to help sequester carbon and stabilize climate change extremes.

Hacktoberfest!

We are participating in hacktoberfest!! Get 4 PR's merged and get a tree planted! We are looking for help with the following: HELP WANTED PROJECT BOARD Our stack is React, Node, Mapbox, and Postgres.

Join Us!

Water the Trees is an open source project run by tree planting volunteers and developers at Code for America. We are looking for developers, designers, and tree planting volunteers to help us build this platform. We are also looking for tree planting organizations to help us build this platform. If you are interested in joining us, please email us at [email protected] or join our #project-waterthetrees channel on slack.


logo
Water The Trees

Water.The.Trees.Demo.mov

Table of Contents

Getting Started

These instructions will get the project up and running on your local machine for development and testing purposes. If you encounter any trouble with these instructions please create an issue with the details of your problem on our issue tracker.

Prerequisites

  • Git
  • Git-LFS
  • Node version 18 or greater.
    • We recommend installing node using nvm. Our install script can install this for you if you don't already have it.
  • Docker

Run Locally

  1. Clone the waterthetrees parent repo and enter the directory.

    git clone https://github.com/waterthetrees/waterthetrees.git
    cd waterthetrees
  2. Run the script to clone the project's repos.

    ./clone_repos.sh
  3. For easy install, run the install script.

    ./install.sh

    Otherwise, you will need to manually set up the backend and frontend.

    Set up the backend:

    • Go into the wtt_server directory.
    • Install the node modules.
    • Create the .env file.
    • Return to the root waterthetrees directory.
    cd wtt_server
    cp .env.example .env
    npm install
    cd ..

    Set up the frontend:

    • Go into the wtt_front directory.
    • Install the node modules.
    • Return to the root waterthetrees directory.
    cd wtt_front
    npm install
    cd ..
  4. The database config is passed into our backend server using environment variables. You will need to ask a team member to provide you with the environment variables (Try our Slack channel). Paste the contents into the wtt_server/.env file.

    Your file tree structure should look something like this.
    
    <pre>
    waterthetrees
    |
    └───wtt_front
    |   │   ...
    |
    └───wtt_server
    │   │   <b>.env</b>
    |   |   .env.example
    │   │
    │   └───server
    │       │   ...
    |
    └───wtt_db
    |   |
    │   └───treeddb.sql
    │
    |   ...
    </pre>
    
  5. Start the database.

    In the root waterthetrees directory, run:

    docker compose up

    When you want to stop the database, run:

    docker compose down
  6. Start the backend.

    Open another terminal tab and go into the wtt_server directory.

    cd wtt_server

    Then run the following to start the backend.

    npm run start
  7. Start the frontend.

    Open another terminal tab and go into the wtt_front directory.

    cd wtt_front

    Then run the following to start the frontend and open it in the browser.

    npm run start:dev & open http://localhost:3000

    When you want to stop the frontend, press Ctrl + C in the terminal.

Contributing

Start by reading the onboarding guide.

Join Us

Join the #proj-waterthetrees Slack channel directly.

or

Join the Code for San Francisco Slack and search for the #proj-waterthetrees channel.

Development

  1. Check the issue tracker to find a feature to build or enhance, a bug that needs fixing, and more.

  2. Create a new branch.

    git checkout -b github-username/feature/build-new-feature
  3. Make the appropriate changes in the files, making sure to follow our Code Conventions.

  4. Commit your changes.

    git commit -am 'Build new feature'
  5. Push to the branch.

    git push origin github-username/feature/build-new-feature
  6. Create a Pull Request.

Bug Reports & Feature Requests

Please use the issue tracker to report any bugs or file feature requests.