diff --git a/.dockerignore b/.nowignore similarity index 86% rename from .dockerignore rename to .nowignore index f1cfc631..446590ad 100644 --- a/.dockerignore +++ b/.nowignore @@ -2,4 +2,4 @@ README.md LICENSE tests -dist \ No newline at end of file +dist diff --git a/README.md b/README.md index 5884e622..e1fac041 100644 --- a/README.md +++ b/README.md @@ -49,7 +49,7 @@ I avoided this by performing *1 extra http request* to fetch the props as json b See [browser.tsx](https://github.com/styfle/react-server-example-tsx/blob/master/src/browser.tsx) for the client-side code. -See [server.tsx](https://github.com/styfle/react-server-example-tsx/blob/master/src/server.tsx) for the server-side code. +See [server.ts](https://github.com/styfle/react-server-example-tsx/blob/master/src/server.ts) for the server-side code. ## Prior art diff --git a/now.json b/now.json index 34d14fca..e80a3f4b 100644 --- a/now.json +++ b/now.json @@ -1,10 +1,18 @@ { "name": "react-server-example-tsx", "alias": "react-tsx.now.sh", - "type": "docker", - "features": { - "cloud": "v2" - }, + "version": 2, + "regions": ["all"], + "builds": [ + { "src": "src/style.min.css", "use": "@now/static" }, + { "src": "package.json", "use": "@now/static-build" }, + { "src": "src/server.ts", "use": "@now/node@canary" } + ], + "routes": [ + { "src": "/style.min.css", "dest": "/src/style.min.css" }, + { "src": "/browser.js", "dest": "/browser.js" }, + { "src": "/(.*)", "dest": "/src/server.ts" } + ], "env": { "NODE_ENV": "production" } diff --git a/package.json b/package.json index d933e006..08ca28c8 100644 --- a/package.json +++ b/package.json @@ -6,7 +6,8 @@ "repository": "styfle/react-server-example-tsx", "scripts": { "start": "node dist/server.js", - "build": "webpack --mode production", + "build": "webpack --mode development", + "now-build": "webpack --mode production", "watch": "webpack --mode development --watch", "prettier": "prettier \"./src/**/*.ts\" \"./src/**/*.tsx\" --write", "test": "tsc --outDir . --sourceMap false && tape tests/**/*.js", diff --git a/src/constants.ts b/src/constants.ts index f801fd5a..4f5aba70 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -1,5 +1,3 @@ -export const reactUrl = '/react.js'; -export const reactDomUrl = '/react-dom.js'; export const faviconUrl = ''; export const stylesUrl = '/style.min.css'; diff --git a/src/server.tsx b/src/server.ts similarity index 83% rename from src/server.tsx rename to src/server.ts index ce9a0c74..c9f2418e 100644 --- a/src/server.tsx +++ b/src/server.ts @@ -1,4 +1,4 @@ -import { createServer } from 'http'; +import { createServer, IncomingMessage, ServerResponse } from 'http'; import { createFactory } from 'react'; import { renderToNodeStream } from 'react-dom/server'; import { createReadStream } from 'fs'; @@ -9,8 +9,6 @@ import { control } from './cache-control'; import { faviconUrl, stylesUrl, - reactUrl, - reactDomUrl, browserUrl, browserMapUrl, propsUrl, @@ -23,8 +21,9 @@ console.log('Production optimization enabled? ', isProd); const AppFactory = createFactory(App); const PORT = process.env.PORT || 3007; const suffix = isProd ? '.production.min.js' : '.development.js'; +const reactVersion = require('../package.json').dependencies.react; -createServer(async (req, res) => { +export default async function handler(req: IncomingMessage, res: ServerResponse) { let { httpVersion, method, url } = req; console.log(`${httpVersion} ${method} ${url}`); if (!url || url === '/') { @@ -52,8 +51,8 @@ createServer(async (req, res) => { ); stream.on('end', () => { res.end(` - - + + `); @@ -62,12 +61,6 @@ createServer(async (req, res) => { res.setHeader('Content-Type', lookup(url)); res.setHeader('Cache-Control', control(isProd, 0)); res.end(JSON.stringify(fetchProps())); - } else if (url === reactUrl || url === reactDomUrl) { - res.setHeader('Content-Type', lookup(url)); - res.setHeader('Cache-Control', control(isProd, 7)); - const name = url.replace('.js', ''); - const file = `./node_modules${name}/umd${name}${suffix}`; - createReadStream(file).pipe(res); } else if (url === stylesUrl) { res.setHeader('Content-Type', lookup(url)); res.setHeader('Cache-Control', control(isProd, 7)); @@ -93,6 +86,10 @@ createServer(async (req, res) => { res.statusCode = 500; res.end('500 Internal Error'); } -}).listen(PORT, () => { - console.log(`Listening on ${PORT}...`); -}); +} + +if (!isProd) { + createServer(handler).listen(PORT, () => { + console.log(`Listening on ${PORT}...`); + }); +} diff --git a/webpack.config.js b/webpack.config.js index b15677a5..7563df74 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -37,7 +37,7 @@ const configs = [ }, { entry: { - server: './src/server.tsx', + server: './src/server.ts', }, output: { path: __dirname + '/dist',