Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vrizo/uibook
Lightweight tool for React components visual testing with media queries
https://github.com/vrizo/uibook
Last synced: 20 days ago
JSON representation
Lightweight tool for React components visual testing with media queries
- Host: GitHub
- URL: https://github.com/vrizo/uibook
- Owner: vrizo
- License: mit
- Created: 2018-11-05T14:24:44.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T23:08:35.000Z (almost 2 years ago)
- Last Synced: 2024-05-16T14:22:23.680Z (6 months ago)
- Language: JavaScript
- Homepage:
- Size: 4.47 MB
- Stars: 228
- Watchers: 7
- Forks: 6
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Uibook
Uibook is a tool for visual testing of React components. It let you quickly
check both desktop and mobile view of your components with real media queries
and different combinations of props.The Key Features:
- Responsive Testing for developers to play with **real media queries**
- Live Text Editing for designers and editors to check their content
- Installed as a Webpack Plugin, it doesn’t require any additional builder.:triangular_flag_on_post: Check amazing Uibook example here:
[https://amplifr.com/uikit](https://amplifr.com/uikit).## Usage
### Quick Install :hatching_chick:
We’ve designed Uibook for seamless integration to your project.
Install it as a webpack plugin, and you’re all set:
Uibook doesn’t require any separate bundler._webpack.config.js_
```js
const UibookPlugin = require('uibook/plugin')module.exports = {
…
plugins: [
new UibookPlugin({
outputPath: '/uibook',
controller: path.join(__dirname, '../src/uibook-controller.js'),
hot: true
})
],
}
```[Read more about installation →](docs/install.md)
[Install in Create React App using CRACO →](docs/install_craco.md)### Describe components in Pages :hatched_chick:
You should define two things only:
1. The Page — simple object with test component name and cases;
2. The Case — set of props and callbacks to the component._button.uibook.js_
```js
import UibookCase from 'uibook/case'
import Button from '../src/button'export default {
component: Button,
cases: [
() => Button,
() => Small button
]
}
```[Read more about configuration →](docs/configure.md)
### Pass Pages to the Controller :baby_chick:
As soon as you finished your first Uibook Page, you’re ready
to write Uibook Controller. This is a place where all
Pages included and passed to UibookStarter :sparkles:_uibook-controller.js_
```js
import UibookStarter from 'uibook/starter'
import ButtonUibook from './button.uibook'export default UibookStarter({
pages: {
Button: ButtonUibook
}
})
```[Read more about Controller →](docs/controller.md)
### Launch :rocket:
There is no need in any additional servers or webpack instances.
Uibook integrates into your project, so just run your bundler
and open `/uibook` (or your custom address — `outputPath`) in a browser.### More information
- **[Troubleshooting](docs/troubleshooting.md)**
- [Examples](docs/examples.md)
- [Ask me](https://twitter.com/vitaliirizo)## Live Text Editing
This mode enables `contentEditable` for each case, allowing managers,
designers and interface editors to preview content in components.## Special thanks
- [@ai](https://github.com/ai)
- [@demiazz](https://github.com/demiazz)
- [@marfitsin](https://github.com/marfitsin)
- [@iadramelk](https://github.com/iadramelk)
- [@ikowalsker](https://www.facebook.com/ikowalsker)
- [@antiflasher](https://github.com/antiflasher)
- [@HellSquirrel](https://github.com/HellSquirrel)Anyone is welcomed to contribute, you can check current tasks
in [PLAN.md](PLAN.md). I would be glad to answer your questions
about the project.