-
Notifications
You must be signed in to change notification settings - Fork 61
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
44596a7
commit 395dd61
Showing
29 changed files
with
3,169 additions
and
3,026 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,10 @@ | ||
module.exports = { | ||
const config = { | ||
trailingComma: 'es5', | ||
tabWidth: 2, | ||
semi: false, | ||
singleQuote: true, | ||
printWidth: 100, | ||
bracketSpacing: true, | ||
} | ||
|
||
export default config |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
export const allModes = { | ||
light: { | ||
theme: 'light', | ||
}, | ||
dark: { | ||
theme: 'dark', | ||
}, | ||
xs: { | ||
viewport: 'breakpointXS', | ||
}, | ||
s: { | ||
viewport: 'breakpointS', | ||
}, | ||
m: { | ||
viewport: 'breakpointM', | ||
}, | ||
l: { | ||
viewport: 'breakpointL', | ||
}, | ||
} as const |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,49 +1,83 @@ | ||
## MealDrop | ||
## Chromatic demo with MealDrop | ||
|
||
Storybook is an open-source tool that helps you develop UI components in isolation. It runs in your codebase, but separately from your application. It's like a sandbox, allowing you to not get distracted by incomplete APIs, flaky data, and other external dependencies. It integrates with frameworks like React, Vue, Svelte, Angular, and many others! | ||
This Storybook is based on the [Mealdrop app](https://github.com/yannbf/mealdrop), a project used in the [Storybook for React apps](https://www.newline.co/courses/storybook-for-react-apps) course by [Yann Braga](https://twitter.com/yannbf). | ||
|
||
With Storybook, you can ease the development of a design system and share a common language with Designers. QA's can get an overview and test functionalities in isolation. Stakeholders can use it for demo purposes. Overall, Storybook helps connect all of these people, greatly improving collaboration! | ||
## To run the project locally | ||
|
||
This is MealDrop, a real-world like project made by [Yann Braga](https://twitter.com/yannbf) (from the Storybook team). It's a food delivery app built from scratch with: | ||
1. Clone the project | ||
2. Run `yarn` to install the dependencies | ||
3. Run `yarn storybook` to start the Storybook server | ||
4. Or run `yarn start` to start the app | ||
|
||
- Modern React with [Typescript](https://www.typescriptlang.org/) and hooks | ||
- Styles with [Styled components](http://styled-components.com/) | ||
- State management [Redux](https://redux.js.org/) with [@reduxjs/toolkit](https://redux-toolkit.js.org/) | ||
- Tests with [Vitest](https://vitest.dev/) and [React Testing Library](https://testing-library.com/docs/react-testing-library/intro/) | ||
- Routing with [React router](https://reactrouter.com/) | ||
- Component explorer [Storybook](https://storybook.js.org/) | ||
### To run Chromatic tests | ||
|
||
Every component of the app is developed and documented in Storybook, and the designs are all in Figma. | ||
```bash | ||
$ CHROMATIC_PROJECT_TOKEN=<your_project_token> yarn chromatic | ||
``` | ||
|
||
[data:image/s3,"s3://crabby-images/0940a/0940acfcbebdf5bf73ecf3ad238e4dc2502af668" alt="MealDrop Demo"](http://mealdrop.vercel.app/) | ||
[data:image/s3,"s3://crabby-images/a84fd/a84fdaca3f6fe3a346c612ebe863831386c58076" alt="MealDrop Storybook"](http://mealdrop.vercel.app/storybook) | ||
[data:image/s3,"s3://crabby-images/bc05c/bc05c79e6f2990007034e31d62e1ad7203d475ec" alt="MealDrop Designs"](https://www.figma.com/file/3Q1HTCalD0lJnNvcMoEw1x/Mealdrop) | ||
--- | ||
|
||
data:image/s3,"s3://crabby-images/95cab/95cab70ac016a0de1111455491217df94b6970d6" alt="" | ||
## What the demo showcases | ||
|
||
You can check this repo as a reference for: | ||
- [Deployed Storybook](https://main--665a454c207e6c8e7fea1174.chromatic.com/) | ||
- [Deployed Mealdrop app](https://mealdrop.vercel.app/) | ||
- [Figma file](https://www.figma.com/design/JHymAhlkm3qUEjy360dL8k/Mealdrop-for-demo?node-id=1091-2985&m=dev) | ||
|
||
- The core concepts of Storybook | ||
- Development workflow with Storybook | ||
- Using the full potential of Storybook, adding components, features and pages | ||
- Testing strategies with Storybook | ||
- Building UI faster | ||
- Mental models for component development | ||
- Tools to improve designer-developer collaboration | ||
- Best practices | ||
### Visual tests | ||
|
||
## What the demo showcases | ||
This project is configured to demonstrate all three Chromatic integrations: | ||
|
||
- [Storybook](https://www.chromatic.com/docs/storybook/): all `*.stories.js` files will be tested by Chromatic | ||
- [Playwright](https://www.chromatic.com/docs/playwright/): `tests/example.spec.ts` E2E test | ||
- [Cypress](https://www.chromatic.com/docs/cypress/): `cypress/e2e/spec.cy.js` E2E test | ||
|
||
### Diffing basics | ||
|
||
[This build](https://www.chromatic.com/build?appId=665a454c207e6c8e7fea1174&number=12) has UI changes that can be reviewed in the Chromatic UI. You can see component level changes and see how those bubble up to the page level. | ||
|
||
data:image/s3,"s3://crabby-images/5e6f2/5e6f28eae267e535db1867f6b908a4ecafd98260" alt="UI changes detected by Chromatic" | ||
|
||
### Testing variants with Modes | ||
|
||
#### Viewports | ||
|
||
The [Header component](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/components-header--default) is a good example of using the viewports addon to test responsiveness. | ||
|
||
data:image/s3,"s3://crabby-images/4a752/4a752ea3d5e288b7f23092549ca8bb2b18816db2" alt="Header component with viewport enabled" | ||
|
||
#### Themes | ||
|
||
The Mealdrop Storybook is configured with a theme switcher that toggles between light and dark themes. This is useful for testing components in with different themes during development. For example, open the [RestaurantCard](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/components-restaurantcard--default) story and toggle the theme switcher. | ||
|
||
<video src="https://github.com/chromaui-demo/mealdrop-demo/assets/42671/ce671c7a-fe43-4b82-a4b9-df32de166f45"></video> | ||
|
||
Theme (and other such variants) plug into Chromatic's [Modes feature](https://www.chromatic.com/docs/modes/) to capture snapshots of different variants of a component. | ||
|
||
data:image/s3,"s3://crabby-images/5c9a3/5c9a32de6a414174af0ea6b7f1ecd60a3a7c994f" alt="Light and dark variants are captured as separate snapshots for the RestaurantCard component" | ||
|
||
### Mocking API requests and interactions | ||
|
||
[Home component](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/userflows-app--home) is a basic example of a story that mocks API data, in this case the restaurants data, using the [Storybook MSW addon](https://storybook.js.org/docs/writing-stories/mocking-network-requests#set-up-the-msw-addon). | ||
|
||
data:image/s3,"s3://crabby-images/6d27e/6d27ee929e43e170be007bcbfb1aec5f0e4b395e" alt="Home page story" | ||
|
||
[RestaurantDetailPage](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/pages-restaurantdetailpage--with-modal-open) is an example of a full page story that also that uses mocked API requests and has [interaction tests](https://www.chromatic.com/docs/interactions/). | ||
|
||
data:image/s3,"s3://crabby-images/84142/841421603a12b38ce7206a2b868e4f169e14cb50" alt="RestaurantDetailPage story with interaction tests" | ||
|
||
[App » ToCheckoutPage](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/userflows-app--to-checkout-page) is another full page example with complex (multi-page) interactions and mocked API requests | ||
|
||
data:image/s3,"s3://crabby-images/aaac6/aaac690c4f24b433573007d784fe8c6006ebddfd" alt="checkout flow test using Storybook interactions" | ||
|
||
### Figma integration | ||
|
||
There are three workflows: | ||
|
||
1. Figma designs can be embedded within Storybook to provide context for developers, eg: [RestaurantCard story in published Storybook](https://main--665a454c207e6c8e7fea1174.chromatic.com/?path=/story/components-restaurantcard--default) | ||
data:image/s3,"s3://crabby-images/a390c/a390c3c6e21e30373faab9edf549805eba6b16a5" alt="Figma designs embedded within Storybook" | ||
|
||
2. Storybook Connect plugin enables designers to view Storybook stories within Figma, eg: [RestaurantCard Figma component](https://www.figma.com/design/JHymAhlkm3qUEjy360dL8k/Mealdrop-for-demo?node-id=1091-2985&m=dev) | ||
<video src="https://github.com/chromaui-demo/mealdrop-demo/assets/42671/4664a74f-efd9-4a75-8454-0a82276bb5a8"></video> | ||
|
||
- <a href="https://mealdrop.vercel.app/storybook/?path=/docs/design-system-colors--docs">Documenting design tokens</a> | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/docs/components-button--docs">Documenting components</a> | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/story/pages-categorydetailpage--default&addonPanel=storybook/a11y/panel&panel=right">Accessibility testing</a> | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/story/pages-restaurantdetailpage--not-found&panel=right">Network mocking</a> | ||
- Rendering components in isolation, from the <a href="https://mealdrop.vercel.app/storybook/?path=/docs/components-button--default&panel=right">simplest</a> to the <a href="https://mealdrop.vercel.app/storybook/?path=/story/userflows-app--home&panel=right">most complex ones</a> | ||
data:image/s3,"s3://crabby-images/2b508/2b50812dcb4f3b1812bea5b175ed47f9770efa3f" alt="" | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/story/userflows-app--to-success-page&addonPanel=storybook/interactions/panel&panel=right">Interaction testing</a> | ||
data:image/s3,"s3://crabby-images/b66bb/b66bb3961549893ebc21e160df422fca93347b4c" alt="" | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/story/components-button--default&addonPanel=STORYBOOK_ADDON_DESIGNS/panel&panel=right">Design integration (Figma)</a> | ||
data:image/s3,"s3://crabby-images/f7094/f7094c072cbb965889a36338a933f789ea3e118a" alt="" | ||
- <a href="https://mealdrop.vercel.app/storybook/?path=/story/components-button--default&globals=theme:dark">Theme switching</a> | ||
data:image/s3,"s3://crabby-images/22e1e/22e1e19245113c8f9e25ff22584936b81cdaef29" alt="" | ||
- And much more! | ||
3. Figma designs in Chromatic: in Chromatic's library view you can view Figma designs alongside Storybook stories and snapshots captured by Chromatic, eg: [RestaurantCard](https://www.chromatic.com/component?appId=665a454c207e6c8e7fea1174&csfId=components-restaurantcard--default&buildNumber=5&k=665dff72d4b0e5916b350a46-dark-designs-true&h=43&b=-6) | ||
<video src="https://github.com/chromaui-demo/mealdrop-demo/assets/42671/63bb41f5-a53b-4e85-a18b-42e6d57f0bd7"></video> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
import globals from 'globals' | ||
import pluginJs from '@eslint/js' | ||
import tseslint from 'typescript-eslint' | ||
import pluginReact from 'eslint-plugin-react' | ||
import pluginUnicorn from 'eslint-plugin-unicorn' | ||
import pluginStorybook from 'eslint-plugin-storybook' | ||
import pluginPrettier from 'eslint-plugin-prettier/recommended' | ||
|
||
/** @type {import('eslint').Linter.Config[]} */ | ||
export default [ | ||
pluginPrettier, | ||
...pluginStorybook.configs['flat/recommended'], | ||
{ | ||
files: ['**/*.{js,mjs,cjs,ts,jsx,tsx}'], | ||
ignores: [ | ||
'node_modules', | ||
'build', | ||
'coverage', | ||
'.nyc_output', | ||
'public', | ||
'src/typings.d.ts', | ||
'!.storybook', | ||
], | ||
languageOptions: { | ||
globals: { ...globals.browser, ...globals.node }, | ||
}, | ||
}, | ||
pluginJs.configs.recommended, | ||
...tseslint.configs.recommended, | ||
{ | ||
...pluginUnicorn.configs.recommended, | ||
rules: { | ||
...pluginUnicorn.configs.recommended.rules, | ||
'unicorn/prevent-abbreviations': 'off', | ||
'unicorn/no-null': 'off', | ||
'unicorn/filename-case': 'off', | ||
'unicorn/no-nested-ternary': 'off', | ||
}, | ||
}, | ||
{ | ||
files: ['**/*.{js,mjs,cjs,jsx,mjsx,ts,tsx,mtsx}'], | ||
...pluginReact.configs.flat.recommended, | ||
settings: { react: { version: 'detect' } }, | ||
rules: { | ||
'react/react-in-jsx-scope': 'off', | ||
'@typescript-eslint/no-explicit-any': 'off', | ||
}, | ||
}, | ||
] |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.