Hi! We're really excited that you are interested in contributing to ACPaaS UI. Before submitting your contribution though, please make sure to take a moment and read through the following guidelines.
-
If you're not yet a member of our DigAnt Café slack community, you can easily join here.
-
Use the #acpaas-ui-react channel on slack to ask questions or discuss changes to the code itself.
-
Use GitHub Issues to report bugs, request features, ask policy questions or propose policy changes.
Note: policy questions are about the way ACPaaS UI is developed and released, or about its architecture. We use github issues to have a public archive of these discussions.
-
The
master
branch is where we ship releases from. Always send PRs tomaster
. -
Commit your changes to a topic branch with a name matching these examples:
feature/more-cowbell
fix/42-broken-cowbell
(the issue id is in the branch name)docs/document-cowbell
-
Work in the
packages
folder and DO NOT check in the top-leveldist
orstyleguide
folders in the commits. -
Make sure
npm test
passes. (see development setup) -
If adding a new feature:
- Add an accompanying test case.
- Provide a convincing reason to add this feature. Ideally you should open a feature request issue first and have it greenlighted before working on it.
-
If fixing a bug:
- Provide a detailed description of the bug in the PR or an accompanying bug report issue linked from the PR (recommended).
- Add appropriate test coverage if applicable.
You will need Node.js version 8+.
After cloning the repo, run:
# install dependencies
$ npm install # or yarn
# run the styleguide app (examples & documentation)
$ npm start
Commit messages should clearly describe what changed. A good commit message completes the sentence "When committed this will …"
# serve styleguidist
$ npm run start
# build all dist files, including npm packages
$ npm run build
# run the full test suite, include linting / type checking
$ npm test
There are some other scripts available in the scripts
section of the package.json
file.
The default test script will do the following: lint with ESLint -> unit tests with coverage -> e2e tests. Please make sure to have this pass successfully before submitting a PR. Although the same tests will be run against your PR on the CI server, it is better to have it working locally beforehand.
ACPaaS UI is supplied as a single library on NPM @acpaas-ui/react-components.
It is released once a week, or more often if there are high priority changes.
If your PR has been merged but not yet released, and it is high priority, please ping the #acpaas-ui-react channel to ask for an out-of-band release (if you're not yet a member of our DigAnt Café slack community, you can easily join here). However, before you do so, container whether you can use a local install or the npm link command instead, or whether you can publish your own development snapshot package under your personal scope on NPM.
A changelog is provided for your convenience.
Maintainers: see the versioning guide for guidance on releases and versioning.
Thank you to all the people who have already contributed to ACPaaS UI!