Skip to content

daphnehanse11/policyengine-app

 
 

Repository files navigation

Welcome 👋 !

This is the official front-end app of PolicyEngine, a non-profit with the mission of computing the impact of public policy for the world.

PolicyEngineWebApp

Prerequisites

We recommend that you use the latest Node version 19. To easily manage your node versions, get the Node Version Manager nvm and then do

nvm install 19 && nvm use 19

Contributing

Choosing an Issue

All of our code changes are made against a GitHub issue. If you're new to the project, go to Issues and search for good first issues label: "good first issue".

We also maintain a priority issue board, available here or under the Projects tab > App Repo Management > Issue Tracker.

Currently, we don't assign contributors. If you see an open issue that no one's opened a PR against, it's all yours! Feel free to make some edits, then open a PR, as described below.

Setting Up

  1. Fork the repo
https://github.com/PolicyEngine/policyengine-app/fork
  1. Install dependencies
make install
  1. Start a server on localhost to see your changes
make debug

Now you're ready to start developing!

Contributing

PolicyEngine follows the industry standard open-source contributions Git workflow:

  • Keep your fork's "master" branch in sync with the original repo by pulling the original repo's code at times; typically (if the original repo is called "upstream" by Git) this means running git pull upstream master, then git push origin master to sync the code to your local repo
  • Create branches on your fork off of your master or main branch. Periodically, if you're working on something for a while, you might also run git rebase master within your feature branch to sync your code with any new changes.
  • When you're done with the feature or bug fix, open the PR from your branch to the live master branch.

If you prefer using a more visual editor, you can add the VS Code GitHub Pull Requests extension and use the Start Working on This Issue feature, which will automate that process. This ensures that we don't run into merge conflicts down the road.

Testing

You've finished your contribution, but now what?

To test your changes against our series of automated tests, run

make test

We also recommend, but do not yet require, that you add tests for any new features or bug-fixes you add, so we can gradually build up the code coverage. We use Jest and the React Testing Library. You can run your tests locally with make test and they will be run again in the PR pre-flight.

We also use ESLint and Prettier to lint our codebase. Before opening a pull request, please be sure to run

make format

This will automatically lint your code for you. Linting is also checked in the PR pre-flight.

Opening a Pull Request

Now you've finished your contribution! Please open a pull request (PR) from your fork against the master branch. At times, it may take some time for the team to review your PR, especially for larger contributions, so please be patient--we will be sure to get to it.

In the first line of your PR, please make sure to include the following:

Fixes {issue_number}

For example:

Fixes #0

This makes it much easier for us to maintain and prune our issue board.

Please try to be detailed in your PRs about the changes you made and why you made them. You may find yourself looking back at them for reference in the future, or needing insight about someone else's changes. We've included a template, but please feel free to add as much as you can. Save yourself a conversation and write it all in the PR!

Here are some best practices for using Git.

When you're ready for review, switch the PR from Draft to Ready for review and add a contributor as a reviewer.

License

Distributed under the AGPL License. See LICENCE for more info.

Acknowledgements

Thanks to Othneil Drew for his README template.

About

PolicyEngine's free web app for computing the impact of public policy.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 57.2%
  • Jupyter Notebook 41.0%
  • TypeScript 1.0%
  • Python 0.6%
  • HTML 0.1%
  • CSS 0.1%