Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Yomguithereal/baobab-react
React integration for Baobab.
https://github.com/Yomguithereal/baobab-react
Last synced: about 2 months ago
JSON representation
React integration for Baobab.
- Host: GitHub
- URL: https://github.com/Yomguithereal/baobab-react
- Owner: Yomguithereal
- License: mit
- Created: 2015-04-14T13:35:44.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2021-05-06T22:52:13.000Z (over 3 years ago)
- Last Synced: 2024-10-12T01:42:39.566Z (2 months ago)
- Language: JavaScript
- Size: 415 KB
- Stars: 309
- Watchers: 15
- Forks: 38
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-react-components-all - baobab-react - React integration for Baobab. (Uncategorized / Uncategorized)
- awesome-react-components - baobab-react - React integration for Baobab. (Code Design / Data Store)
- awesome-react - baobab-react - React integration for Baobab
- awesome-ccamel - Yomguithereal/baobab-react - React integration for Baobab. (JavaScript)
- awesome-list - baobab-react - React integration for Baobab. (Code Design / Data Store)
- awesome-react-components - baobab-react - React integration for Baobab. (Code Design / Data Store)
- awesome-react-components - baobab-react - React integration for Baobab. (Code Design / Data Store)
- awesome-react-components - baobab-react - React integration for Baobab. (Code Design / Data Store)
- fucking-awesome-react-components - baobab-react - React integration for Baobab. (Code Design / Data Store)
README
[![Build Status](https://travis-ci.org/Yomguithereal/baobab-react.svg)](https://travis-ci.org/Yomguithereal/baobab-react)
# baobab-react
Welcome to [baobab](https://github.com/Yomguithereal/baobab)'s [React](https://facebook.github.io/react/) integration (from v2.0.0 and onwards).
Implemented patterns:
* [Hooks](docs/hooks.md)
* [Higher order components](docs/higher-order.md) (curried so also usable as ES7 decorators)
* [Mixins](docs/mixins.md)## Summary
* [Installation](#installation)
* [On root & branches](#on-root--branches)
* [Patterns](#patterns)
* [Hooks](#hooks)
* [Mixins](#mixins)
* [Higher Order Components](#higher-order-components)
* [Common pitfalls](#common-pitfalls)
* [Contribution](#contribution)
* [License](#license)## Installation
You can install `baobab-react` through npm:
```
npm install baobab-react
```*Peer dependencies*
This library necessitate that you install `baobab >= 2.0.0` and `react >= 0.13.x` (plus `react-dom >= 0.14.x` if required).
Then require the desired pattern and only this one will be loaded (meaning that your browserify/webpack bundle, for instance, won't load unnecessary files and end up bloated).
*Example*
```js
var mixins = require('baobab-react/mixins');
```## On root & branches
In order to keep component definitions detached from any particular instance of Baobab, the mixins, higher order components etc. are divided into two:
* The **Root** aims at passing a baobab tree through context so that child component (branches) may use it. Typically, your app's top-level component will probably be a root.
* The **Branches**, bound to cursors, get their data from the tree given by the root.This is necessary so that isomorphism can remain an enjoyable stroll in the park (your UI would remain a pure function).
## Patterns
### Hooks
[Dedicated documentation](docs/hooks.md)
### Higher Order Components
[Dedicated documentation](docs/higher-order.md)
### Mixins
[Dedicated documentation](docs/mixins.md)
## Common pitfalls
**Controlled input state**
If you need to store a react controlled input's state into a baobab tree, remember you have to commit changes synchronously through the `tree.commit` method or else you'll observe nasty cursor jumps in some cases.
```js
var PropTypes = require('baobab-react/prop-types').PropTypes;var Input = React.createClass({
mixins: [mixins.branch],
cursors: {
inputValue: ['inputValue']
},
contextTypes: {
tree: PropTypes.baobab
},
onChange: function(e) {
var newValue = e.target.value;// If one edits the tree normally, i.e. asynchronously, the cursor will hop
this.cursor.set(newValue);// One has to commit synchronously the update for the input to work correctly
this.cursor.set(newValue);
this.context.tree.commit();
},
render: function() {
return ;
}
});
```## Contribution
Contributions are obviously welcome.
Be sure to add unit tests if relevant and pass them all before submitting your pull request.
```bash
# Installing the dev environment
git clone [email protected]:Yomguithereal/baobab-react.git
cd baobab-react
npm install# Running the tests
npm test# Linting
npm run lint# Building a independent version
npm run build# or per pattern
npm run build-mixins
npm run build-higher-order
npm run build-hooks
```## License
MIT