/
server.js
55 lines (46 loc) · 1.32 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
var express = require('express')
, exphbs = require('express-handlebars')
, request = require('request')
, path = require('path')
, assert = require('assert')
, bodyParser = require('body-parser');
var React = require('react');
var ReactDOMServer = require('react-dom/server');
require("node-jsx").install();
var app = express();
app.set('views', path.join(__dirname, 'views'));
app.engine('.hbs', exphbs({defaultLayout: 'main', extname: '.hbs'}));
app.set('view engine', '.hbs');
app.use(express.static(__dirname + '/public'));
//app.use(bodyParser.json()); // support json encoded bodies
//app.use(bodyParser.urlencoded({ extended: true })); // support encoded bodies
// React Components
var OfferTable = React.createFactory(require('./components/OfferTable'));
// This opbject will hold the initial app state.
var initialStateForComponents = {
offerTable: {
title: "Markypoo"
},
offerTableRow: {
offers: [{
offer: "Column 1",
url: "Column 2",
actions: "Column 3"
},
{
offer: "Column 1",
url: "Column 2",
actions: "Column 3"
}
]
}
};
// Routes
app.get('/', function(req, res) {
res.render('index', {
reactHtml: ReactDOMServer.renderToStaticMarkup(OfferTable({})),
initialState: JSON.stringify(initialStateForComponents)
});
});
app.listen(6767);
console.log("server started at port 6767");