2015-07-03 17:40:12 -07:00
|
|
|
import React from 'react';
|
|
|
|
import Router from 'react-router';
|
|
|
|
import Location from 'react-router/lib/Location';
|
2015-06-29 12:01:56 -07:00
|
|
|
import debugFactory from 'debug';
|
2015-07-02 23:44:34 -07:00
|
|
|
import { app$ } from '../../common/app';
|
2015-06-29 12:01:56 -07:00
|
|
|
import { Cat } from 'thundercats';
|
2015-06-29 09:50:25 -07:00
|
|
|
|
2015-06-29 12:01:56 -07:00
|
|
|
const debug = debugFactory('freecc:servereact');
|
2015-07-01 15:14:10 -07:00
|
|
|
|
|
|
|
// add routes here as they slowly get reactified
|
|
|
|
// remove their individual controllers
|
2015-06-29 12:01:56 -07:00
|
|
|
const routes = [
|
2015-07-03 21:46:22 -07:00
|
|
|
'/Hikes',
|
|
|
|
'/Hikes/:id',
|
|
|
|
'/jobs'
|
2015-06-29 09:50:25 -07:00
|
|
|
];
|
|
|
|
|
2015-06-29 12:01:56 -07:00
|
|
|
export default function reactSubRouter(app) {
|
2015-07-02 23:44:34 -07:00
|
|
|
var router = app.loopback.Router();
|
2015-06-29 09:50:25 -07:00
|
|
|
|
|
|
|
routes.forEach(function(route) {
|
|
|
|
router.get(route, serveReactApp);
|
|
|
|
});
|
|
|
|
|
|
|
|
app.use(router);
|
|
|
|
|
|
|
|
function serveReactApp(req, res, next) {
|
2015-07-03 17:40:12 -07:00
|
|
|
const fcc = new Cat();
|
2015-07-08 22:53:26 -07:00
|
|
|
const location = new Location(req.path, req.query);
|
2015-06-29 09:50:25 -07:00
|
|
|
|
|
|
|
// returns a router wrapped app
|
2015-07-03 17:40:12 -07:00
|
|
|
app$(location)
|
2015-06-29 09:50:25 -07:00
|
|
|
// if react-router does not find a route send down the chain
|
2015-07-03 21:46:22 -07:00
|
|
|
.filter(function([ initialState ]) {
|
|
|
|
if (!initialState) {
|
|
|
|
debug('tried to find %s but got 404', location.pathname);
|
|
|
|
return next();
|
2015-06-29 09:50:25 -07:00
|
|
|
}
|
2015-07-03 21:46:22 -07:00
|
|
|
return !!initialState;
|
2015-06-29 09:50:25 -07:00
|
|
|
})
|
2015-07-03 21:46:22 -07:00
|
|
|
.flatMap(function([ initialState ]) {
|
2015-06-29 09:50:25 -07:00
|
|
|
// call thundercats renderToString
|
|
|
|
// prefetches data and sets up it up for current state
|
2015-07-03 17:40:12 -07:00
|
|
|
return fcc.renderToString(
|
2015-07-03 21:46:22 -07:00
|
|
|
React.createElement(Router, initialState)
|
2015-07-03 17:40:12 -07:00
|
|
|
);
|
2015-06-29 09:50:25 -07:00
|
|
|
})
|
|
|
|
// makes sure we only get one onNext and closes subscription
|
2015-07-03 17:40:12 -07:00
|
|
|
.flatMap(function({ data, markup }) {
|
2015-06-29 09:50:25 -07:00
|
|
|
debug('react rendered');
|
2015-07-03 17:40:12 -07:00
|
|
|
res.expose(data, 'data');
|
2015-06-29 09:50:25 -07:00
|
|
|
// now render jade file with markup injected from react
|
2015-07-03 17:40:12 -07:00
|
|
|
return res.render$('layout-react', { markup: markup });
|
2015-06-29 09:50:25 -07:00
|
|
|
})
|
|
|
|
.subscribe(
|
|
|
|
function(markup) {
|
|
|
|
debug('jade rendered');
|
|
|
|
res.send(markup);
|
|
|
|
},
|
|
|
|
next
|
|
|
|
);
|
|
|
|
}
|
2015-06-29 12:01:56 -07:00
|
|
|
}
|