Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tswayne/react-helper

Easily add react to your pre-existing (or new) mvc node application
https://github.com/tswayne/react-helper

express mvc node nodejs react react-components sailsjs

Last synced: 12 days ago
JSON representation

Easily add react to your pre-existing (or new) mvc node application

Awesome Lists containing this project

README

        

[![npm](https://img.shields.io/npm/v/react-helper.svg)](https://www.npmjs.com/package/react-helper)
[![Build Status](https://travis-ci.org/tswayne/react-helper.svg?branch=master)](https://travis-ci.org/tswayne/react-helper)

# React Helper
### Easily add react to your pre-existing (or new) mvc node application
There are tons of resources and tools out there to help developers get started with react and start a fresh new react app; however, there
are not many tools out there to help those who want to add react to an existing app (built with node). React-helper makes it extremely easy to
add react components to your views, so you can jump right into writing react components without having to worry too much about setup.

## Installing
##### Adding to your app
`npm install react-helper --save`

### Table of Contents
* [Features](#features)
* [Getting Started](#getting-started)
* [Manually adding react-helper](#manual)
* [Setup](#setup)
* [Server Side Rendering](#server-side)
* [Express, Sails, and Hapi](#frameworks)
* [Example application](#example)

## Features:
* Setting up is a breeze. Add react to your app with one command using the cli.

`react-helper init -w`

* Extremely easy to add react components to your views.

**Controller**:

```javascript
const reactHelper = require('react-helper');
const component = reactHelper.renderComponent('SignUp')
res.render('view-to-render', {component})
```

**View**: _example using handlebars templating engine_

```html

This view has react in it


{{{component}}}
```
* Pass server-side data to components: You can _easily_ pass data from your server to your react components.

**Controller**: _example passing results from mongo query to react component_

```javascript
db.collection('users').find().toArray(function(err, users) {
const component = reactHelper.renderComponent('ListUsers', users)
return res.render('view-to-render', {component})
}
```

* Server-side rendering: use the full power of react by server-side rendering your components by just passing the react component (or its relative path) to react helper instead of a string.

**Controller**: _example passing results from mongo query to react component_

```javascript
const reactHelper = require('react-helper');
const SignUp = require('../path/to/SignUp');
const component = reactHelper.renderComponent(SignUp) //IT'S THIS EASY
res.render('view-to-render', {component})
```

## Getting started

### Manually add react-helper to your application
Getting started is simple:

_For the examples, I will be using showing snippets of code from an express application using handlebars templating engine, but this helper will work with any framework and templating engine_

1. Create a directory where you will be keeping all of your react code (something like "client"). An express app usually looks similar to this:
```javascript
project/
controllers/
middlewares/
models/
public/
views/
client/ //<-- New directory
```

2. Within the client directory you will need to create a file that will register your components with react-helper. This file will also be your _entry point_ for webpack (more on that later).

That file should live here:
```javascript
...
views/
client/
//Other organizational directories for your react code
components/
index.js // <-- New file
```
The file should look something like this:
```javascript
const reactHelper = require('reactHelper');
const SomeComponent = require('./path/to/a/component');
// Require all components you want to use in your views...

reactHelper.register({SomeComponent});
// Register each of the components you will be using in your views
reactHelper.register({OtherComponent});
```
3. Then, in your controller (or whatever code renders your view template) all you have to do is call react-helper's "renderComponent", and pass the results to your view:

**Controller**:
```javascript
const reactHelper = require('react-helper');
const component = reactHelper.renderComponent('SignUp')
res.render('view-to-render', {component})
```

**View**:
```html

This view has react in it


{{{component}}}
```

### Setup

The only setup needed is to add webpack to your project, point it to the react-helper registration file, and include the resulting javascript file in your project.

1. The only requirement react-helper has for the webpack config is that the entry point is the file that registers all of the components using react-helper.

In the example above it would look something like this:
```javascript
entry: [
'./client/index.js'
],
```

2. Then, assuming your webpack's output looks something like:

```javascript
output: {
filename: 'react-bundle.js',
path: './public/javascript',
},
```

Adding it to your application would look just like adding any other local javascript file.

```html

```

## Server side rendering
Server-side rendering can be very [useful](https://www.smashingmagazine.com/2016/03/server-side-rendering-react-node-express/). This library makes it very easy to server-side render your components. There are two methods to server-side rendering:
**If you are using JSX in your components and would like to render your components server side** - you must use [babel-register](https://babeljs.io/docs/usage/babel-register/) or pre-compile your files, see https://github.com/babel/example-node-server as an example. More coming soon.

1. In your controller, pass the relative path of your component instead of the registered component name to renderComponent:
```
const reactHelper = require('react-helper')
const path = require('path')
const component = reactHelper.renderComponent(path.join(__dirname, '../path/to/SignUp'))
res.render('view-to-render', {component})
```

2. Pass the component itself to renderComponent.
```
const reactHelper = require('react-helper');
const SignUp = require('../path/to/SignUp');
const component = reactHelper.renderComponent(SignUp)
res.render('view-to-render', {component})
```

## Express, Sails, and Hapi
Add react-helper to your favorite node framework by using [express-react-helper](https://github.com/tswayne/express-react-helper) or [hapi-react-helper](https://github.com/tswayne/hapi-react-helper)!

## Shout out!
This library is inspired by React On Rails (https://github.com/shakacode/react_on_rails), a library that makes it insanely easy to add react to a Rails application.

## Contributing
Feel free to open issues or pull requests!