Vulcan/packages/nova-routing/lib/routing.jsx

92 lines
2.7 KiB
React
Raw Normal View History

import Telescope, { Components, Actions } from 'meteor/nova:lib';
2016-04-22 10:46:09 +09:00
import React from 'react';
2016-06-10 19:19:32 +09:00
import { ReactRouterSSR } from 'meteor/reactrouter:react-router-ssr';
2016-06-29 09:15:52 +02:00
import Helmet from 'react-helmet';
import Cookie from 'react-cookie';
import ReactDOM from 'react-dom';
import ApolloClient from 'apollo-client';
import { getDataFromTree, ApolloProvider } from 'react-apollo';
import { meteorClientConfig } from 'meteor/nova:apollo';
import { configureStore } from "./store.js";
import { Callbacks, addRoute } from 'meteor/nova:core';
Meteor.startup(function initNovaRoutesAndApollo() {
2016-06-11 16:36:18 +09:00
const Routes = addRoute({name:"app.notfound", path:"*", component:Components.Error404});
const indexRoute = _.filter(Routes, route => route.path === '/')[0];
const childRoutes = _.reject(Routes, route => route.path === '/');
delete indexRoute.path; // delete the '/' path to avoid warning
2016-06-13 16:02:27 +09:00
const AppRoutes = {
path: '/',
component: Components.App,
indexRoute,
childRoutes,
};
2016-06-14 10:01:44 +09:00
/*
Hooks client side and server side definition
*/
let history;
let initialState;
let store;
let client;
// Use history hook to get a reference to the history object
const historyHook = newHistory => history = newHistory;
const clientOptions = {
historyHook,
rehydrateHook: state => {
// console.log('rehydrated state', state);
initialState = state
},
wrapperHook(app, loginToken) {
// console.log('wrapper hook initial state', initialState);
client = new ApolloClient(meteorClientConfig({cookieLoginToken: loginToken}));
store = configureStore(client, initialState, history);
return <ApolloProvider store={store} client={client}>{app}</ApolloProvider>
},
props: {
onUpdate: () => {
Callbacks.run('router.onUpdate');
// clear all previous messages
store.dispatch(Actions.messages.clearSeen());
},
},
};
2016-06-12 12:11:05 +09:00
const serverOptions = {
historyHook,
htmlHook: (html) => {
const head = Helmet.rewind();
return html.replace('<head>', '<head>'+ head.title + head.meta + head.link);
},
preRender: (req, res, app) => {
Cookie.plugToRequest(req, res);
//console.log('preRender hook', app);
// console.log(req.cookies);
return Promise.await(getDataFromTree(app));
},
dehydrateHook: () => {
// console.log(client.store.getState());
const state = client.store.getState();
// https://github.com/apollostack/apollo-client/issues/845
delete state.apollo.queries;
delete state.apollo.mutations;
return client.store.getState();
},
// fetchDataHook: (components) => components,
};
ReactRouterSSR.Run(AppRoutes, clientOptions, serverOptions);
});