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(`
-
-
+
+