Contributions to gitcoin could come in different forms. Some contribute code changes, others contribute docs, others help answer questions from users, help keep the infrastructure running,
We welcome all contributions from folks who are willing to work in good faith with the community. No contribution is too small and all contributions are valued.
Contributions to Gitcoin are governed by the Contributor Covenant version 1.4. All contributors and participants agree to abide by its terms. To report violations, shoot out an email to [email protected]
The Code of Conduct is designed and intended, above all else, to help establish a culture within the project that allows anyone and everyone who wants to contribute to feel safe doing so.
Open, diverse, and inclusive communities live and die on the basis of trust. Contributors can disagree with one another so long as they are done in good faith and everyone is working towards a common goal.
Issues in gitcoin/web
are the primary means by which bug reports and
general discussions are made. A contributor is allowed to create an issue,
discuss, and provide a fix if needed.
Before opening an issue, https://waffle.io/gitcoinco/web is a good place to go to see if there are any current issues with similar key words. This helps us cut down on duplicate tickets.
When you open an issue, you'll notice four templates (bug, custom, discussion, feature) with the user-story format we like for our issue reports. When starting a new issue, please do your best to be as detailed and specific as possible.
- Bug report - use this to create a bug report to help us improve Gitcoin
- Discussion - use this template to start a discussion
- Feature request - use this to suggest a project idea
- Custom report - use this to report an issue that doesn't fall under any other category
As Gitcoin is still at its early stages, drop by gitcoin.co/slack and say hi to know what's next / to get your answers cleared up.
Pull Requests are the way in which concrete changes are made to the code and documentation.
You must install pre-commit in order to enable our
precommit hooks and pre-commit install
from your gitcoinco/web
root directory.
In order to make use of the pre-commit
hooks used for this repository, you should have a valid installation of node
/npm
, isort
(pip install isort
), yapf
(pip install yapf
), stylelint
(npm install -g stylelint
), and eslint
(npm install -g eslint
).
User facing copy / text should be run through Django Translation Framework. For example,
- HTML user-facing pieces of copy are in
{% blocktrans %}
or{% trans %}
fields. - javascript user-facing pieces of copy are in
ngettext
fields. - each of the
views.py
user-facing pieces of copy are ingettext_lazy
fields - each of the models
help_text
s are internationalized - as are all the emails in
marketing/mails.py
Take a look at /styleguide-alpha
(ui_inventory.html), for a quick reference of user interface components.
If you are contributing user-facing assets, interface components or other relevant visuals,
then please add them to our UI Inventory page.
Fork the project on GitHub and clone your fork locally.
git clone [email protected]:username/web.git
cd web
git remote add upstream https://github.com/gitcoinco/web.git
git fetch upstream
It's always better to create local branches to work on a specific issue. Makes
life easier for you if you are the kind who enjoys multiple things parallely.
These should also be created directly off of the master
branch.
git checkout -b my-branch -t upstream/master
To keep the style of the Javascript code consistent we have a basic linting configured. To check your contributed code for errors run npm run eslint
. To make life easy use the automatic fixing by running npm run eslint:fix
before your commit.
- Use the pre-configured eslint for Javascript
- Avoid trailing whitespace & un-necessary white lines
- Indentation is as follows
- 1 tab = 2 spaces for
.html
and.js
files - 1 tab = 4 spaces for everything else
- 1 tab = 2 spaces for
- Use
rem
for CSS when applicable - Add relevant unit tests for all new Python logic and update existing tests to accommodate new logic.
-
Ensure your code changes adhere to our styling and linting standards:
npm run eslint:fix; npm run stylelint:fix; isort -rc --atomic .
-
List all your changes as a list if needed else simply give a brief description on what the changes are.
-
All lines at 100 columns.
-
If your PR fixed an issue, Use the
Fixes:
prefix and the full issue URL. For other references useRefs:
.Examples:
Fixes: https://github.com/gitcoinco/web/issues/87
Refs: https://github.com/gitcoinco/web/issues/91
-
Sample commit A
if you can write down the changes explaining it in a paragraph which each line wrapped within 100 lines. Fixes: https://github.com/gitcoinco/web/issues/87 Refs: https://github.com/gitcoinco/web/issues/91
Sample commit B
- list out your changes as points if there are many changes - if needed you can also send it across as - all wrapped within 100 lines Fixes: https://github.com/gitcoinco/web/issues/87 Refs: https://github.com/gitcoinco/web/issues/91
-
Squashing and Merging your commits to make our history neater is always welcomed, but squashing can be handled during the merge process.
Ensure you neat description on what your PR is for, so that it's easier for folks to understand the gist of it before jumping to the the code / doc.
As a best practice, once you have committed your changes, it is a good idea
to use git rebase
(not git merge
) to ensure your changes are placed at the
top. Plus merge conflicts can be resolved
git fetch upstream
git rebase upstream/master
Please ensure that your pull request follows all of the community guidelines to include:
- Title is descriptive and generally focused on what the PR addresses (If your PR is a work in progress, include
WIP
in the title. Once the PR is ready for review, please removeWIP
) - Description explains what the PR achieves or addresses
- If the PR modifies the frontend in any way, please attach screenshots and/or GIFs of all purposeful changes (before and after screens are recommended)
- The PR passes all CI checks, to include Stickler, codecov, and Travis.
Note: Please remember to optimize/compress your image assets via: make compress-images
(Requires: jpeq-recompress, optipng, and svgo in PATH
)
You can install the necessary binaries via:
npm install -g jpeg-recompress-bin pngquant-bin svgo
brew install optipng
Q: I need to add static assets... Where to I put them?
All assets that will be used as static resources must be placed into their appropriate place in the app/assets
directory.
Q: I've added the new assets to the appropriate directory, but can't seem to use them. How do I make Django recognize my newly added assets?
Run: make collect-static
if using Docker or cd app; python3 manage.py collectstatic -i other
for virtualenv/local setup.
Additionally, you can check out the Django Managing Static Files Documentation
Welcome to the gitcoin community. Lets Grow Open Source Software.