React UI Components for ManageIQ
Purpose
List of components
Name | Documentation | Description |
---|---|---|
HelloCmp | doc/comp-a/some-cmp/hello.component | Example component |
Technologies
Most components are using these libraries:
Build process
Build process is using webpack which is set to extract external libraries so the final library is as small as possible.
Webpack is used to build library so the final files can be imported into any other application. Library target is set to umd.
List of external libraries
- React
- ReactDOM
- PropTypes
- Redux
- ReactRedux
- ReactSelect
- PFReact
- Lodash
Settings of these externals can be found in constants.js. Importing any of these libraries will not make final file bigger, but importing such file needs to ensure, that libraries used in this component are loaded.
Architecture
Development Environment
This library uses LTS of Node environment, to start coding you have to run
$ [npm|yarn] install
No matter what tool you choose to develop with you have to run to load external dependencies.
$ [npm|yarn] run vendor
Development tools
To create new set of components you can create new folder inside src/
folder with index.js
as entrypoint to your new
components, where you will export [components|reducers|actions] for other application to use. To create custom styles for
your components, create [style|styles|index].scss
next to index.js
as entrypoint to your styles.
To properly use storybook and tests you have to create two folders inside your component's folder.
stories
for storybooktests
for jest tests
Local development
You can choose from three ways of how to code and test your application on local machine.
[npm|yarn] start
1. It will automatically watch your files and store final files into dist
folder.
This way you can create some components use npm link to create symlink and use npm link inside your server application to include these components and debug them inside your environment.
[npm|yarn] run server
2. It will automatically watch your files, run webpack-dev-server and
serve your new components in demo app. To use your newly created components feel free to change demo/demo-app.jsx
to include
your components and you can debug them in node server environment.
The server will run at http://localhost:8080.
[npm|yarn] run storybook
3. It will automatically watch your files and presents them using storybook, if you want to use your new components, edit stories inside stories/index.stories.js and debug them in nice storybook UI.
The storybook server will run at http://localhost:6006.
this
to methods
Binding You have two ways how to create methods inside classes. One is based on babel using preset-stage-0, the other is based on decorators using autobind-decorator
- Babel based method
import * as React from 'react';
export class ExampleClass extends React.Component {
someMethod = () => {
//some work with this, which is component's this
}
}
- Decorator based method
import * as React from 'react';
import autobind from 'autobind-decorator';
export class ExampleClass extends React.Component {
@autobind
someMethod() {
//some work with this, which is component's this
}
}
Generating of documentation
This project is using react-docgen to generate documentation out of your comments in components.
If you wish to generate new documentation you have to have react-docgen
installed as global dependency and run
$ scripts/documentation/genDoc.sh
This script will generate new documentation, run it trough and saves new markdown inside /doc folder.