Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jameslnewell/rechannel
Opinionated glue for creating web apps with `react` and `redux`.
https://github.com/jameslnewell/rechannel
boilerplate react react-router redux server-side-rendering ssr
Last synced: about 1 month ago
JSON representation
Opinionated glue for creating web apps with `react` and `redux`.
- Host: GitHub
- URL: https://github.com/jameslnewell/rechannel
- Owner: jameslnewell
- Created: 2016-03-14T06:09:51.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2017-03-16T20:11:32.000Z (almost 8 years ago)
- Last Synced: 2024-11-16T01:37:18.153Z (2 months ago)
- Topics: boilerplate, react, react-router, redux, server-side-rendering, ssr
- Language: JavaScript
- Size: 36.1 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# rechannel
Opinionated glue for building web apps with React and Redux.
Glues together `react`, `redux`, `react-router`, `react-router-redux`, `redial` and `redux-devtools-extension`.
Useful for both client side _and_ UniversalJS apps.> This package is experimental and the API may receive breaking changes before v1.0.0.
## Installation
npm install --save rechannel react react-dom react-redux \
react-router react-router-redux redial redux## Usage
### Client
```javascript
import rechannel from 'rechannel';
import routes from './routes';
import reducer from './reducer';//creates a store, sets up the router, pre-fetches the necessary data
// and renders the page
rechannel({
routes,
reducer
});```
> Note: If you're not using a server you'll have to create your own HTML file.
Try the [example](https://github.com/jameslnewell/rechannel/tree/master/example/client.js).
### Server
```javascript
import express from 'express';
import rechannel from 'rechannel';
import routes from './routes';
import reducer from './reducer';const app = express();
app.use('/', express.static(`./public`));
//returns a middleware function that creates a store, sets up the router, pre-fetches necessary data
// and renders the page
app.use(rechannel({
routes,
reducer
}));const server = app.listen(8000, () => {
const host = server.address().address;
const port = server.address().port;
console.log('App running at http://%s:%s', host, port);
});```
Try the [example](https://github.com/jameslnewell/rechannel/tree/master/example/server.js).
## API
```js
rechannel(options : object)
```Create a store, set up the router, pre-fetch necessary data
and render the page.**Options:**
Common options:
- `routes : Element|function` _Required_. A `` element or a function creating a `` element. Function are passed the `getState()` and `dispatch()` methods from the redux store (useful for restricting access in a `onEnter` hook). Learn more about configuring routes in the [React Router docs](https://github.com/reactjs/react-router/blob/master/docs/guides/RouteConfiguration.md).
- `reducer : object` _Required_. A keyed object of reducer functions that may be passed to `combineReducers()`. Learn more about reducer functions in the [Redux docs](http://redux.js.org/docs/Glossary.html#reducer).
- `middleware : array` Optional. An array of middleware functions. Learn more about middleware functions in the [Redux docs](http://redux.js.org/docs/Glossary.html#middleware).
- `enhancer : array` Optional. An array of enhancer functions. Learn more about enhancer functions in the [Redux docs](http://redux.js.org/docs/Glossary.html#store-enhancer).
- `history : History` Optional. A [history](https://www.npmjs.com/package/history) instance. Default's to `react-router`'s `browserHistory` on the client and the result of `react-router`'s `createMemoryHistory` on the server. Learn more about history objects in the `react-router` [Histories docs](https://github.com/reactjs/react-router/blob/master/docs/guides/Histories.md).Hooks:
- `$init : function` Optional. Called after the redux store is initialised. May return a promise.
- `$load : function` Optional. Called after any data is (pre-)loaded. May return a promise.Client specific options:
- `element : HTMLElement` Optional. The `HTMLElement` which React will render into. Defaults to `document.querySelector('#app')`.
Server specific options:
- `html : Component` Optional. A component that renders the root HTML. Passed the Redux `state` and the React Router component(s) as `children` via `props`. Defaults to [this component](https://github.com/jameslnewell/rechannel/tree/master/lib/createHtml.js).
- `send : function(res, html)` Optional. A function that allows customisation of the response sent by the server. Passed the response object and a HTML string.**Returns:**
Returns nothing on the client. Returns an `express` middleware function on the server.
**Note:** On the client, routes aren't re-created for each time you navigate to a new page, if you're using a factory function to create the routes and utilising the `cookies` or `query` parameters,
the routes won't be re-created with the new query or cookie values. The route factory function will only be re-evaluated when you re-load the page.```js
createHtml(options : object)
```Create a React component for rendering `` on the server.
**Options:**
- `title : string|function`
- `script : string|Array`
- `style : string|Array`**Returns:**
Returns a React component for rendering `` on the server.
## Change log
### 0.10.0
- add: support server rendered async routes as per https://github.com/ReactTraining/react-router/blob/master/docs/guides/ServerRendering.md#async-routes
### 0.9.0
- add: added `headers` as a parameter for all hooks
- add: now passing `query`, `cookies` and `headers` to your `Html` component### 0.8.0
- add: added the ability to provide a custom `history` object
- add: added `redux-immutable-state-invariant` to non-production builds which trigger an error when the redux state has been mutated
- add: added validation around some of the `options` to assist developers in finding problems earlier### 0.7.0
- add: added a `query` parameter to the `$init`, `$load` and `fetch` hooks
### 0.6.2-3
- fix: fixed a bug where routes weren't being re-created per request so conditional routing resulted in outcomes
### 0.6.0
- add: added `$init()` and `$load()` hooks
### 0.5.0
- add: allow routes to be a function
### 0.4.2
- fix: add keyword metadata
### 0.4.1
- fix: `createHtml()` parameters `script` and `style` need to be cast to arrays
### 0.4.0
- add: `createHtml()` parameters `script` and `style` now accept an array of script and style files
### 0.3.0
- break: turned the `Html` component into a factory function to allow customisation of the `` title, script and style names
## To do
- write tests
- rename `fetch` trigger to `load`
- allow the `reducer` to be a single reducer function
- allow the `middleware` and `enhancer` parameters to be a function call that receives the `req` in order to be configured e.g. `redux-effects-cookie`
- clean-up `locals` passed to `redial` - allow them to be user configurable