Skip to content

Latest commit

 

History

History
205 lines (147 loc) · 10.7 KB

CONTRIBUTING.md

File metadata and controls

205 lines (147 loc) · 10.7 KB

Contributing to BEEQ Design System

First off, thanks for taking the time to contribute and help out to make BEEQ better than it is today! 💪😁 🎉

As a contributor, here are the guidelines we would like you to follow:

✍️ Code of Conduct

We have adopted the Contributor Covenant as our Code of Conduct, and we expect project participants to adhere to it. Please read the full text so that you can understand what actions will and will not be tolerated.

We Develop with Github

So you wanna contribute some code? That's great! We use Github to host code, track issues and feature requests, as well as accept pull requests.

Pull Requests

Pull requests are the best way to propose changes to the codebase. We actively welcome your pull requests:

  1. Fork the repo and start your branch from develop, following our branching strategy.
  2. If you've added code that should be tested, add Unit tests.
  3. If you've added a new component that should be tested, please add all the corresponding End-to-End Tests.
  4. If you've changed APIs, update the documentation.
  5. Ensure the test suite passes.
  6. Make sure your code doesn't introduce new code quality violations.
  7. Issue that pull request!

❗️When creating a Pull Request (PR), please make sure that the PR's name also respects the commit message format and always use Squash and merge.

Any contributions you make will be under the Apache 2.0 Software License

First of all, please be aware that when you submit code changes, your submissions are understood to be under the same Apache 2.0 that covers the project. Feel free to contact the maintainers at [email protected] if that's a concern.

Report an Error or Bug

Report a bug by opening a new issue. When you are opening an issue, please be sure to report as much information as you can to allow us to replicate the problem and faster find the solution.

Great Bug Reports tend to have:

  • A quick summary and/or background
  • Steps to reproduce
    • Be specific!
    • Give a sample code if you can
  • What you expected would happen
  • What happens
  • Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)

🛠 Project setup

For running the project in your local development environment please follow the README instructions.

🎨 Styleguides

Code formatting

Follow the style you see used in the repository! Consistency with the rest of the project always trumps other considerations. It doesn't matter what you choose for your daily code implementation or if you have your style but, please, make sure to have configured Prettier on your IDE/Code Editor.

Branching strategy

We follow a GitHub'ish branch strategy, where:

  • main our base branch used for stable releases

For GitHub flow, the general process is as follows:

  • Every change that is worked on is branched directly off of main into a feature branch.
  • Once a feature is ready it is tested on the feature branch and the code is reviewed before being merged to main.
  • Once the feature has been merged to main it should be released to production.

Github flow is pretty simple and straightforward, but if you want to know more about it, please check the Github Flow documentation.

  • ❗️ When starting to work on a new feature or bugfix, branch off from the main branch:
git switch -c feat/<feature-name> main
git checkout -b feat/<feature-name> main
# or
git switch -c fix/<fix-name> main
git checkout -b fix/<fix-name> main
  • ❗️ When starting to work on a hotfix:
git switch -c hotfix/<fix-name> main
git checkout -b hotfix/<fix-name> main
  • For changes related to tests and documentation we recommend:
git switch -c tests/<test-change> main
git checkout -b tests/<test-change> main
# or
git switch -c docs/<doc-change> main
git checkout -b docs/<doc-change> main
  • Other branch naming conventions (all of them should branch off from the main branch):
    • chore: changes to the build process or auxiliary tools and libraries such as documentation generation
    • style: changes that do not affect the meaning of the code (white space, formatting, missing semi-colons, etc)
    • refactor: a code change that neither fixes a bug nor adds a feature
    • perf: a code change that improves performance

Git Commit Messages

We have very precise rules over how our git commit messages should be formatted. This leads to readable messages that are easy to follow when looking through the project history. Think that we can also use the git commit messages to generate our changelog 😃

  • Use the present tense ("Add feature" not "Added feature").

  • Use the imperative mood ("Move cursor to..." not "Moves cursor to...").

  • Limit the first line to 72 characters or less.

  • Reference issues and pull requests liberally after the first line.

  • When only changing documentation, include [ci skip] in the commit title.

  • Ensure your commit message match the following pattern:

    <type>[optional scope]: <subject>
    
    [optional body]
    
    [optional footer(s)]
    

More details can be found in the Conventional Commits Guidelines

Type

Must be one of the following:

  • feat: a new feature
  • fix: a bug fix
  • docs: documentation only changes
  • style: changes that do not affect the meaning of the code (white space, formatting, missing semi-colons, etc)
  • refactor: a code change that neither fixes a bug nor adds a feature
  • perf: a code change that improves performance
  • test: adding missing tests
  • chore: changes to the build process or auxiliary tools and libraries such as documentation generation

Subject

The subject contains a succinct description of the change:

  • do not capitalize the first letter
  • do not place a period . at the end
  • the entire length of the commit message must not go over 72 characters
  • describe what the commit does, not what issue it relates to or fixes
  • be brief, yet descriptive - we should have a good understanding of what the commit does by reading the subject

Breaking changes

PR that introduces BREAKING CHANGES should include the ! character in the type and an explanation of the changes in the PR's body or footer. For example:

refactor(checkbox)!: rename `isChecked` property with `checked`

BREAKING CHANGE: the `isChecked` property has been renamed to `checked`.

The `isChecked` property (`is-checked` attribute) is no longer supported in the checkbox component and has been renamed to `checked` property/attribute.

Breaking Change section should start with the phrase "BREAKING CHANGE: " followed by a summary of the breaking change, a blank line, and a detailed description of the breaking change that also includes migration instructions.

Similarly, a Deprecation section should start with "DEPRECATED: " followed by a short description of what is deprecated, a blank line, and a detailed description of the deprecation that also mentions the recommended update path.

👌 Recommended IDE Extensions

We would like all our contributors to have the same experience while developing for BEEQ, hence here is a list of Extensions we primarily use with Visual Studio Code and recommend everyone to installed in their local environment:

If you use a different IDE than VSCode, please try to find and install the equivalent extensions for your specific Editor.