44 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { renderToString, renderToStaticMarkup } from 'react-dom/server';
 | |
| 
 | |
| import MainApp from '../client/main/App';
 | |
| 
 | |
| import createElement from './utils/createElement';
 | |
| import createHTML from './utils/createHTML';
 | |
| import createScript from './utils/createScript';
 | |
| import getEntryPoint from './utils/getEntryPoint';
 | |
| import getGlobalScripts from './utils/getGlobalScripts';
 | |
| import MainTemplate from './utils/MainTemplate';
 | |
| 
 | |
| const doctype = '<!DOCTYPE html>';
 | |
| const globalURLs =
 | |
|   process.env.NODE_ENV === 'production' || process.env.NODE_ENV === 'staging'
 | |
|     ? {
 | |
|         '@emotion/core': '/@emotion/core@10.0.6/dist/core.umd.min.js',
 | |
|         react: '/react@16.7.0/umd/react.production.min.js',
 | |
|         'react-dom': '/react-dom@16.7.0/umd/react-dom.production.min.js'
 | |
|       }
 | |
|     : {
 | |
|         '@emotion/core': '/@emotion/core@10.0.6/dist/core.umd.min.js',
 | |
|         react: '/react@16.7.0/umd/react.development.js',
 | |
|         'react-dom': '/react-dom@16.7.0/umd/react-dom.development.js'
 | |
|       };
 | |
| 
 | |
| export default function serveMainPage(req, res) {
 | |
|   const content = createHTML(renderToString(createElement(MainApp)));
 | |
|   const entryPoint = getEntryPoint('main', 'iife');
 | |
|   const elements = getGlobalScripts(entryPoint, globalURLs).concat(
 | |
|     createScript(entryPoint.code)
 | |
|   );
 | |
| 
 | |
|   const html =
 | |
|     doctype +
 | |
|     renderToStaticMarkup(createElement(MainTemplate, { content, elements }));
 | |
| 
 | |
|   res
 | |
|     .set({
 | |
|       'Cache-Control': 'public, max-age=14400', // 4 hours
 | |
|       'Cache-Tag': 'main'
 | |
|     })
 | |
|     .send(html);
 | |
| }
 |