CSS classes and React components designed to build Cozy apps.
If you plan to build a webapp to run on Cozy, you'll probably want to use a simple and elegant solution to build your interfaces without the mess of dealing with complex markup and CSS. Then Cozy UI is here for you!
Check the styleguide to see all the variables, mixins, classes, utilities and how to use them with only CSS classes.
Check out UI components to see how to use ready made React components.
Add Cozy UI to a dependency to your project.
npm install cozy-ui
If you use the transpiled components (from cozy-ui/transpiled/react
), you need to import the stylesheet (once):
import Button from 'cozy-ui/transpiled/react/Button'
import 'cozy-ui/transpiled/react/stylesheet.css'
<Button />
You're now ready to use Cozy UI's React components
React components only come with the needed style, nothing more, but you may need some more utility classes to build your apps.
To do so you have at your disposal a special CSS build cozy-ui.utils.min.css
that you can add like this:
import 'cozy-ui/dist/cozy-ui.utils.min.css'
The entire library is also available as a good ol’ CSS library. You can simply add it to your app by linking the distributed minified file.
<link media="all" rel="stylesheet" href=“cozy-ui/dist/cozy-ui.min.css" />
If you want to develop inside cozy-ui, you need a local version cozy-ui.
git clone git@github.com:cozy/cozy-ui.git
It is convenient when modifying a component to use the styleguide site.
yarn start # Transpile the files in watch mode
yarn build:css:all # Build CSS files needed by the documentation
yarn start:doc # Run the styleguide in watch mode
If you want to add a new icon to cozy-ui, you must follow these steps:
- First verify that the SVG doesn't have any
fill
properties. Remove them if necessary - Add the SVG in the
assets/icons
folder - Generate the react component by running
yarn makeSvgr assets/icons/[new icon folder]/[new icon file name]
- Update the documentation by adding the icon in
react/Icon/Readme.md
insideSVGr icons
andAvailable UI icons
sections - Don't forget to check the icon's color on different theme (inverted, etc.)
- Update the tests by running
yarn build && yarn test -u
Sometimes, you want to develop on a component, from the context of an app.
Then you need to link cozy-ui with yarn link
.
cd cozy-ui
yarn link
yarn start # Launch transpilation
Then in your application folder, you can link to your local Cozy UI.
You can use rlink
instead of yarn link
. It will prevent common build problems due
to module resolution inside symlinked folders.
cd my-app
rlink cozy-ui # Prefer rlink to yarn link
yarn start
All your modifications in your local Cozy UI will now be visible in your application!
When sending a PR, if your changes have graphic impacts, it is useful for the reviewers if you have deployed a version of the styleguidist containing your changes to your repository.
yarn build:doc:react
yarn deploy:doc --repo git@github.com:USERNAME/cozy-ui.git
- Use material UI whenever possible
- Override material UI components inside theme.js when necessary
- Avoid stylus to style new components
- Prefer withStyles / useStyles from material UI
- Use semantic variables for colors
withStyles(theme => ({
root: {
- backgroundColor: 'var(--paleGrey)',
+ backgroundColor: theme.palette.background.default
}
}))
Be aware that snapshots in unit tests use the transpiled version of cozy-ui. Therefore if you make changes and need to update the snapshots, you need to transpile first.
yarn build && yarn test -u
We suggest to use @testing-library/react
over enzyme
for tests. We have
historically used enzyme
but we prefer the philosophy behind testing-library
since
it pushes to test for what the user sees.
For complex components, we expose testing helpers in the testing
file in their respective folders.
import { getCloseButton, getAllDialogs } from 'cozy-ui/transpiled/react/CozyDialogs/testing'
it('should close dialog', () => {
const onClose = jest.fn()
const root = render(<MyApp onCloseDialog={onClose} />)
const dialog = getDialog(root)
const closeBtn = getCloseButton(dialog)
fireEvent.click(closeBtn)
expect(onClose).toHaveBeenCalled()
})
Components in cozy-ui
are showcased with React Styleguidist. To prevent UI regressions,
for each PR, each component is screenshotted and compared to the master version to find any
regression (thanks Argos !).
If your app uses React Styleguidist, cozy-ui
provides rsg-screenshots
, a CLI tool to take
screenshots of your components (uses Puppeteer under the hood).
yarn add cozy-ui
# The rsg-screenshots binary is now installed
yarn build:doc:react # Build our styleguide, the output directory is docs/react
rsg-screenshots --screenshot-dir screenshots/ --styleguide-dir docs/react
# Each component in the styleguide will be screenshotted and saved inside the
screenshots/ directory
See our travis configuration for more information.
Cozy UI is developed by Cozy Cloud and distributed under the MIT license.
Cozy is a platform that brings all your web services in the same private space. With it, your web apps and your devices can share data easily, providing you with a new experience. You can install Cozy on your own hardware where no one profiles you.
You can reach the Cozy Community by:
- Chatting with us on IRC #cozycloud on irc.freenode.net
- Posting on our Forum
- Posting issues on the Github repos
- Mentioning us on Twitter