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!
Cozy UI relies heavily on Material UI v4 and it can be useful to know how it works.
Check out UI components to see how to use ready made React components.
Check the styleguide to see all the variables, mixins, classes, utilities and how to use them with only CSS classes.
Add Cozy UI to a dependency to your project.
yarn add cozy-uiIf you use the transpiled components (from cozy-ui/transpiled/react), you need to import the stylesheet (once):
import Button from 'cozy-ui/transpiled/react/deprecated/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 [email protected]:cozy/cozy-ui.gitFirst nvm use (to set node version as defined in .nvmrc) then yarn install
It is convenient when modifying a component to use the styleguide site.
yarn makeSpriteAndPalette # Create sprite and palette
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 modeYou may need to start css as well:
yarn start:css # Create cozy-ui css
yarn start:css:utils # Create cozy-ui utility csstips: If you are starting js and css to have full control, and you want to link results in an application, in addition to all your start process you need to launch yarn build:js each time you want to see your modification from cozy-ui inside your application.
If you want to add a new component, you must follow these steps:
- Add the new component in /reactfolder with itsREADME.mdfile
- Expose it in the API by adding it in react/index.js
- Add it in the documentation by modifying docs/styleguide.config.js
- If necessary you can add snapshots for it by modifying react/examples.spec.jsxand updating themyarn makeSpriteAndPalette && yarn build && yarn test -u
- Remember to propagate the possible refwithReact.forwardRef. See forwardRef documentation
- Try to think of ARIA attributes if you are coding new components
Be careful to respect MUI API when creating a new component. See our guidelines to create a new component.
When renaming or moving a Cozy-UI component, it may cause a breaking change. In this case, you should provide a codemod as much as possible to fix it.
- Use material UI whenever possible
- Override material UI components inside makeOverrides.jswhen necessary
- Avoid stylus to style new components based on MUI and prefer /helpers/makeStyles
- Use semantic variables for colors from stylus/settings/palettes.styl, or color fromthemeobjects inmakeStyles
If you want to add a new icon to cozy-ui, you must follow these steps:
- If you SVG file is an icon (not an illustration), verify that the file doesn't have any fill or fill-opacity properties. Remove them if necessary
- Add the SVG in the assets/icons/[ui || illus]folder
- Optimize it with yarn svgo assets/icons/[ui || illus]/[new icon file name]
- Generate the react component by running yarn makeSvgr assets/icons/[ui || illus]/[new icon file name]
- Update the documentation by adding the new file in react/Icon/Readme.md. If it's an icon, add it in SVGr icons and Available UI icons sections, or in SVGr illustrations and Available illustrations sections if it's an illustration
- Don't forget to check the icon's color on different theme (inverted, etc.)
- Update the tests by running yarn makeSpriteAndPalette && 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. Since cozy-ui is transpiled, when linking you must first yarn release. If you change the icons, or the palette, you must run yarn release again.
cd cozy-ui
yarn makeSpriteAndPalette # if first time
yarn link
yarn start # Launch transpilation
yarn makeSpriteAndPalette # if you change icons or paletteThen 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.
If your application doesn't use cozy-ui directly as dependency but through a library, you have to use rlink inside your application folder, not inside the library's one.
rlink only copies the build and not the node_modules of cozy-ui, so you have to install a version of cozy-ui before making a rlink.
cd my-app
rlink cozy-ui # Prefer rlink to yarn link
yarn startAll 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 fork's repository.
Don't forget to change USERNAME by yours.
yarn build:all && yarn deploy:doc --repo [email protected]:USERNAME/cozy-ui.gitdeploy:doc failed, you need to checkout your dev branch by doing git checkout -
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 makeSpriteAndPalette && yarn build && yarn test -uWe 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 !).
Before launching commands, you may need to change executablePath in scripts/screenshots/prepares.js to /Applications/Chrome.app/Contents/MacOS/Chrome or /Applications/Chromium.app/Contents/MacOS/Chromium depends on your system.
Then you have to install dependencies:
yarn add puppeteer@"22.15.0" --dev --exactBefore creating any screenshots, make sure you have built everything:
yarn build:allNow you are ready to create screenshots:
mkdir -p ./screenshots
yarn screenshots --mode react --viewport desktop --screenshot-dir ./screenshots/reactDesktopYou can also specify a component to screenshot by adding --component NameOfTheComponent and change viewport to mobile size:
yarn screenshots --mode react --viewport 300x600 --screenshot-dir ./screenshots/reactDesktop --component SidebarIt may be interesting to create pristine screenshots, and then create screenshots of your modified component and compare them locally:
mkdir -p ./pristine_screenshots
yarn screenshots --mode react --viewport desktop --screenshot-dir ./pristine_screenshots/reactDesktop --component Sidebar
# make modifications on Sidebar component
# build everything again
# screenshot it as described before, then
mkdir -p ./diffs
yarn screenshots:serverSee our travis configuration for more information.
Cozy-ui relies on many packages to work, but we tend to want it to be more agnostic. So this is the package list and usage:
- @date-io/date-fns => DatePicker
- chart.js => PieChart
- cozy-interapp => IntentIframe
- date-fns => DateMonthPicker, DatePicker, I18n
- filesize => FilePickerBodyItem
- final-form, final-form-array => react-final-form, react-final-form-array => Contacts/AddModal
- react-markdown => Markdown
- react-select => Contacts/GroupsSelect, SelectBox
- react-virtuoso => Table/Virtualized, GridList/Virtualized
- rooks => BottomSheet, Table/Virtualized, UploadQueue
- @popperjs/core => react-popper => ActionMenu/NotInlineWrapper
- react-remove-scroll => BottomDrawer, Overlay
- react-swipeable-views => InfosCarroussel, ViewStack
- cozy-client => lot of components
- cozy-device-helper => AppLinker, Dialog, Paywall, Storage
- cozy-flags => AppSections, Paywall, QualificationGrid
- cozy-intent => ActionsMenu, AppLinker, Dialog, Paywall, SelectionBar
- react-dnd => Table/Virtualized/DnD, GridList/Virtualized/DnD
- react-dnd-html5-backend => Table/Virtualized/DnD, GridList/Virtualized/DnD
- cozy-device-helper => ActionMenu, Modal
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