Thank you for your interest in Peaks.js!
We love hearing feedback from people who use our software, so if you build something interesting using this library, please let us know.
Contributions are welcomed and encouraged. If you're thinking of writing a new feature, please first discuss the change you wish to make, either by raising an issue, or contacting us directly, e.g, by email.
-
If we agree with your feature proposal, we'll work with you to develop and integrate the feature. But please bear with us, as we may not always be able to respond immediately.
-
Please avoid making commits directly to your copy of the
master
branch. This branch is reserved for aggregating changes from other people, and for mainline development from the core contributors. If you commit tomaster
, it's likely that your local fork will diverge from the upstream repository. -
Before working on a change, please ensure your local fork is up to date with the code in the upstream repository, and create a feature branch for your changes.
-
Please don't change the
version
field in package.json, or update CHANGELOG.md. We'll do that when preparing a new release. -
Please follow the existing coding conventions, and ensure that there are no linting errors (
npm run lint
). The eslint config doesn't specify all our coding conventions, so please try to be consistent. (We realise there are some inconsistencies in the codebase already, we're slowly working to resolve them.) -
For commit messages, please follow these guidelines, although we're not fussy about use of imperative mood vs past tense. In particular, avoid commit messages that include Angular-style metadata.
-
Please add test cases for your feature, and ensure all tests are passing (
npm run test
). -
When merging a feature branch, core contributors may choose to squash your commits, so that the feature is merged as a single logical change.
When it's time to publish a new release version, e.g,. to npm, create a single commit on master
with the following changes only:
- Increment the
version
field in package.json - Describe the new features in this release in CHANGELOG.md
Tag this commit using the form vX.Y.Z
and push the commit using git push origin master --tags
.