From 83f02b1ebc4ceda8226fb6d9c004241c0c47ae8d Mon Sep 17 00:00:00 2001 From: kolaente Date: Tue, 10 Oct 2023 17:47:20 +0200 Subject: [PATCH] chore: update contributing guidelines --- CONTRIBUTING.md | 3 ++ docs/content/doc/development/development.md | 50 +++++++++++++++++++-- 2 files changed, 49 insertions(+), 4 deletions(-) create mode 100644 CONTRIBUTING.md diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..e6a315bec --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,3 @@ +# Contribution Guidelines + +Please check out the guidelines on https://vikunja.io/docs/development/ diff --git a/docs/content/doc/development/development.md b/docs/content/doc/development/development.md index 0fc1fd49e..43fd9d18a 100644 --- a/docs/content/doc/development/development.md +++ b/docs/content/doc/development/development.md @@ -17,7 +17,9 @@ menu: ## General To contribute to Vikunja, fork the project and work on the main branch. -Once you feel like your changes are ready, open a PR in the respective repo. +Once you feel like your changes are ready, open a PR in the respective repo [on our Gitea instance](https://kolaente.dev/vikunja). +We cannot accept PRs on mirror sites. + A maintainer will take a look and give you feedback. Once everyone is happy, the PR gets merged and released. If you plan to do a bigger change, it is better to open an issue for discussion first. @@ -38,11 +40,51 @@ Make sure to check the other doc articles for specific development tasks like [t The code for the frontend is located at [code.vikunja.io/frontend](https://code.vikunja.io/frontend). More instructions can be found in the repo's README. -You need to have [pnpm](https://pnpm.io/) and nodejs in version 16 or 18 installed. +You need to have [pnpm](https://pnpm.io/) and Node.JS in version 18 or higher installed. -## Git flow +## Pull Requests + +All Pull Requests must be made [on our Gitea instance](https://kolaente.dev/vikunja). +We cannot accept PRs on mirror sites. + +Please try to make your pull request easy to review. +For that, please read the [*Best Practices for Faster Reviews*](https://github.com/kubernetes/community/blob/261cb0fd089b64002c91e8eddceebf032462ccd6/contributors/guide/pull-requests.md#best-practices-for-faster-reviews) guide. +It has lots of useful tips for any project you may want to contribute to. +Some of the key points: + +- Make small pull requests. + The smaller, the faster to review and the more likely it will be merged soon. +- Don't make changes unrelated to your PR. + Maybe there are typos on some comments, maybe refactoring would be welcome on a function… + but if that is not related to your PR, please make *another* PR for that. +- Split big pull requests into multiple small ones. + An incremental change will be faster to review than a huge PR. +- Allow edits by maintainers. This way, the maintainers will take care of merging the PR later on instead of you. + +### PR title and summary + +In the PR title, describe the problem you are fixing, not how you are fixing it. +Use the first comment as a summary of your PR. +In the PR summary, you can describe exactly how you are fixing this problem. +Keep this summary up-to-date as the PR evolves. + +If your PR changes the UI, you must add **after** screenshots in the PR summary. +If your PR closes an issue, you must note that in a way that both GitHub and Gitea understand, i.e. by appending a paragraph like + +```text +Fixes/Closes/Resolves #. +Fixes/Closes/Resolves #. +``` + +to your summary. +Each issue that will be closed must stand on a separate line. + +If your PR is related to a discussion in the forum, you must add a link to the forum discussion. + +### Git flow The `main` branch is the latest and bleeding edge branch with all changes. Unstable releases are automatically created from this branch. +New Pull-Requests should be made against the `main` branch. A release gets tagged from the main branch with the version name as tag name. @@ -52,4 +94,4 @@ Backports and point-releases should go to a `release/version` branch, based on t We're using [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) because they greatly simplify generating release notes. -It is not required to use them when creating a PR, but appreciated. +It is not required to use them when creating a PR, but appreciated. \ No newline at end of file