We welcome feedback and help with Psammead. By participating in Psammead, you agree to abide by the Code of Conduct. Please take a moment to read it.
We appreciate all forms of contribution - not just code. Contribution can include adding documentation, requesting clarification, making typo corrections and much more.
Psammead has a "Definition of Done" which applies to changes proposed to its main branch, latest
. When you make a pull request, please check that your contribution matches this.
Component Structure
As discussed in the README, Psammead is a library of shared components following the container / components pattern. Whether you are creating a component from scratch, or preparing to move an existing React component to Psammead, make sure that your component is presentational and reusable. The component should accept props if needed and implement minimal logic. A presentational component shouldn’t handle either fetching or mutation of data.
A component should have this file structure:
├── README.md
├── CHANGELOG.md
├── package.json
├── package-lock.json
├── src
│ ├── __snapshots__
│ │ └── index.test.jsx.snap
│ ├── index.jsx
│ ├── index.stories.jsx
│ └── index.test.jsx
The src/
folder is necessary for separation of concerns, as a dist/
folder containing the transpiled version of the component is generated at publish time. The dist/
folder will contain the transpiled version of any .jsx
files in the src/
folder (saved as ES5 .js
), with the exception of *.stories.jsx
and *.test.jsx
files.
NB: the __snapshots__
directory is optional.
package.json
The package.json
is namespaced with @bbc/psammead-*
e.g. @bbc/psammead-headings
.
Include the following authorship and repository information in your package. Replace the team name and email address if appropriate.
"author": {
"name": "BBC Psammead Maintainers",
"email": "[email protected]"
},
"repository": {
"type": "git",
"url": "https://github.com/bbc/psammead/tree/latest/packages/psammead-headings"
},
Also make sure you define the entry-point to the transpiled version of your component:
"main": "dist/index.js",
For example, if your component's main entry-point is src/foo.jsx
, you should point "main"
to "dist/foo.js"
.
Tests
- When you run
npm test
all unit tests should pass and there should be 100% test coverage of the component. - No JS or CSS lint errors should be present.
- Your component should be fully accessibility-tested. There's a test guide for testers and a checklist for developers as well as guides for designers, business analysts, product owners and project managers.
Creating custom tests
By default, Psammead's npm run test
runs unit tests through Jest. However, so long as adequate test coverage exists, it's not mandatory to test a component with Jest.
Custom tests must adhere to the following conventions:
- The component's test script must be named
test
. This ensures the test script will be run by Psammead's root levelnpm test
command. - The component's testing framework and/or assertion libraries must be installed as devDependencies in the component's
package.json
. - Test files cannot be prefixed with ".test", as Psammead's Jest configuration looks for files ending in
.test.jsx
and.test.js
.
For a sample usage of custom Mocha/Chai tests with Psammead, please refer to #247.
Accessibility Swarms
When you add a component to this repository, you should carry out an Accessibility Swarm, ideally including team members from multiple disciplines and using the Assistive Technology we support.
For changes to an existing component, a shorter swarm with fewer people should be conducted.
Here are detailed steps on how to run accessibility swarms.
As a result of the swarm, you may find some issues with your implementation. These should be documented and where relevant, GitHub Issues should be raised.
CHANGELOG
The changelog should follow the following convention:
# PackageName Changelog
| Version | Description |
|---------|-------------|
| 0.1.0 | [PR#49](https://github.com/bbc/psammead/pull/49) Initial creation of package |
README
The README.md
should follow this template:
# (package name) · (badges)
## Description
(high-level summary that will be accessible to product/UX/Test, plus link to Storybook, explain the different cases)
## When to use this component
(including where it is currently used)
## When not to use this component
(if this is not known, can leave the section empty)
## Installation
`npm install (package-name)`
## Props
(a table of all the component's props, following the template below)
| Argument | Type | Required | Default | Example |
|-----------|---------------------|----------|---------|-----------------|
| prop-name | description of type | Yes/No | `value` | `example input` |
## Usage
(A code block containing an example usage of the component, including importing)
## Accessibility notes
(ensuring they make sense to non-technical audiences)
## Roadmap
(what we have planned for this component)
## Additional notes
(link to any relevant ADRs)
## Contributing
Psammead is completely open source. We are grateful for any contributions, whether they be new components, bug fixes or general improvements. Please see our primary contributing guide which can be found at [the root of the Psammead respository](https://github.com/bbc/psammead/blob/latest/CONTRIBUTING.md).
### [Code of Conduct](https://github.com/bbc/psammead/blob/latest/CODE_OF_CONDUCT.md)
We welcome feedback and help on this work. By participating in this project, you agree to abide by the [code of conduct](https://github.com/bbc/psammead/blob/latest/CODE_OF_CONDUCT.md). Please take a moment to read it.
### License
Psammead is [Apache 2.0 licensed](https://github.com/bbc/psammead/blob/latest/LICENSE).
When linking to other pages from a component's README, we advise you do so only by absolute URL, and avoid the use of relative paths. Component READMEs are displayed in a variety of places, including NPM and Storybook, and this helps ensure the intended meaning is preserved.
If you wish to exclude one or more sections of this template, we advise you do so by simply commenting out the heading, like so:
<!-- ## Roadmap -->
After merging a pull request into latest
, please follow these steps to ensure that the changes are published to npm and to the Psammead Storybook https://bbc.github.io/psammead.
- Publish Packages
To make your changes available on the npm registry please publish any package changes. The instructions to do this can be found in the the repository README - Publish Storybook
When changes are made to a component its important to ensure the changes are visible on the hosted storybook. To do this please follow the instructions on the repository README