This checklist is used whenever someone wants to merge a new component to the system. The steps below are edited from Nathan Curtis’ Component QA article.
Before you complete the steps below, please consider the reusability of the component by using this flowchart:
Credit: original flowchart from the Vanilla Framework.
Does the component apply visual style — color, typography, icons, space, borders, and more — using appropriate variables, and does it meet our visual guidelines?
Has the design and implementation accounted for accessibility? Please use our accessibility checklist.
Does it incorporate responsive display patterns and behaviors as needed? Is the component designed from a mobile-first perspective? Do all touch interactions work as expected?
Does it cover all the necessary variations (primary, secondary, compact) and states (default, hover, active, disabled, loading), given intended scope?
Is each dynamic word or image element resilient to too much, too little, and no content at all, respectively? How long can labels be, and what happens when you run out of space?
Does it fit well when placed next to or layered with other components to form a larger composition?
Do all behaviors function as expected? For responsive tabs, are menus (for overflow tabs) behaving correctly in varied device settings?
Has the component visual quality and accuracy been assessed across Safari, Chrome, Firefox, IE, and other browsers across relevant devices? Please adhere to our browser support requirements.
Please use the documentation template for documenting the new component.
Making an example component for each component is a very good idea.
The file of the example component should reside into a /docs
folder in the same folder where the component is defined and its name should be example.jsx
. For instance for the <Popover />
component:
// component definition
- client/component/popover/index.jsx
// example component
- client/component/popover/docs/example.jsx
By convention the name of example component should ends with the Example
word so for in the Popover case the name should be PopoverExample
. To show the correct name on /devdocs/design
, define the displayName
for the example component:
class PopoverExample extends PureComponent {
static displayName = 'PopoverExample';
// ...
}
Components will appear in the Playground if they have the following requirements satisfied:
- An example Component in /components/component-name/docs/example.jsx
- An exampleCode property on the example Component
- An
export ComponentName from components/component-name
statement inplayground-scope.js
- An
export ComponentName from components/component-name/docs/example.jsx
statement incomponent-examples.jsx
Components which satisfy these requirements will also have a playground appear in Devdocs Design.