Contributing to this project should be as easy and transparent as possible, whether it's:
- Reporting a bug
- Discussing the current state of the code
- Submitting a fix
- Proposing new features
- Helping with translation
Github is used to host code, to track issues and feature requests, as well as accept pull requests. We use Hosted Weblate for translations but old-school pull requests for those are accepted as well.
Pull requests are the best way to propose changes to the codebase.
- Fork the repo and create your branch from
main
. - If you've changed (or added) something, update the documentation.
- Make sure your code lints (using
scripts/lint
). - Test you contribution (using
scripts/test
). Contributions that don't provide tests may take longer to be incorporated. - Issue that pull request!
In short, when you submit code changes, your submissions are understood to be under the same MIT License that covers the project. Feel free to contact the maintainers if that's a concern.
Report bugs using Github's issues
GitHub issues are used to track public bugs. Report a bug by opening a new issue; it's that easy!
Great Bug Reports tend to have:
- A quick summary and/or background
- Steps to reproduce
- Be specific!
- Give sample code if you can.
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)
People love thorough bug reports. I'm not even kidding.
Use black to make sure the code follows the style. (Running scripts/lint
will run black
)
This custom component is based on integration_blueprint template.
It comes with development environment in a container, easy to launch if you use Visual Studio Code. With this container you will have a stand alone Home Assistant instance running and already configured with the included configuration.yaml
file.
If you need help with your environment or understanding the code, join us at our Discord #developers channel.
By contributing, you agree that your contributions will be licensed under its MIT License.