Files
TechRadarAJR/js/server.js
2017-04-04 18:10:50 +02:00

58 lines
1.8 KiB
JavaScript

import React from 'react';
import { renderToString } from 'react-dom/server';
import { createStore } from 'redux';
import { Provider } from 'react-redux';
import {assetUrl} from '../common/config'
import App from './components/App';
import appReducer from './reducer';
export const renderPage = (radar, pageName) => {
// Create a new Redux store instance
const store = createStore(appReducer, {
...radar,
pageName,
pageState: {},
});
let pageTitle;
// Render the component to a string
const html = renderToString(
<Provider store={store}>
<App onSetTitle={(title) => { pageTitle = title; }} />
</Provider>
)
// Grab the initial state from our Redux store
const preloadedState = store.getState()
// Send the rendered page back to the client
return renderFullPage(html, pageTitle, preloadedState);
}
const renderFullPage = (html, pageTitle, preloadedState) => {
return `
<html>
<head>
<meta charset="utf-8">
<title>${pageTitle} | AOE Technology Radar</title>
<link rel="stylesheet" href="${assetUrl('css/styles.css')}"/>
<link rel="stylesheet" href="https://d1azc1qln24ryf.cloudfront.net/114779/Socicon/style-cf.css?c2sn1i">
<link rel="shortcut icon" href="${assetUrl('favicon.ico')}" type="image/x-icon">
<meta name="format-detection" content="telephone=no">
<meta name="viewport" content="width=device-width, maximum-scale=1.0, initial-scale=1.0, user-scalable=0">
<meta property="og:title" content="${pageTitle} | AOE Technology Radar" />
<meta property="og:image" content="${assetUrl('logo.svg')}" />
</head>
<body>
<div id="root">${html}</div>
<script>
window.__TECHRADAR__ = ${JSON.stringify(preloadedState)}
</script>
<script src="${assetUrl('js/bundle.js')}"></script>
</body>
</html>
`
}