-
-
Save nuno/c0da875f4fc2ec26ebc7cda08954bb94 to your computer and use it in GitHub Desktop.
AngularV5 + MaterializeCss(without Jquery) support for Server Side Rendering
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import 'zone.js/dist/zone-node'; | |
import 'reflect-metadata'; | |
import { enableProdMode } from '@angular/core'; | |
import { ngExpressEngine } from '@nguniversal/express-engine'; | |
import * as express from 'express'; | |
import { join } from 'path'; | |
import { readFileSync } from 'fs'; | |
const domino = require('domino'); | |
// Faster server renders w/ Prod mode (dev mode never needed) | |
enableProdMode(); | |
// Express server | |
const app = express(); | |
const compression = require('compression'); | |
const PORT = process.env.PORT || 3000; | |
const DIST_FOLDER = join(process.cwd(), 'dist'); | |
// Our index.html we'll use as our template | |
const template = readFileSync(join(DIST_FOLDER, 'browser', 'index.html'), 'utf8').toString(); | |
const win = domino.createWindow(template); | |
global['window'] = win; | |
global['document'] = win.document; | |
global['M'] = {}; | |
global['cash'] = require('cash-dom'); | |
global['$'] = global['cash']; | |
global['Element'] = win.Element; | |
global['NodeList'] = win.NodeList; | |
// * NOTE :: leave this as require() since this file is built Dynamically from webpack | |
const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./dist/server/main.bundle'); | |
const { provideModuleMap } = require('@nguniversal/module-map-ngfactory-loader'); | |
app.use(compression()); | |
app.engine('html', ngExpressEngine({ | |
bootstrap: AppServerModuleNgFactory, | |
providers: [ | |
provideModuleMap(LAZY_MODULE_MAP) | |
] | |
})); | |
app.set('view engine', 'html'); | |
app.set('views', join(DIST_FOLDER, 'browser')); | |
// Server static files from /browser | |
app.get('*.*', express.static(join(DIST_FOLDER, 'browser'), { maxAge: '1y' })); | |
// All regular routes use the Universal engine | |
app.get('*', (req, res) => { | |
res.render('index', { | |
req: req, | |
res: res | |
}); | |
}); | |
// Start up the Node server | |
app.listen(PORT, () => { | |
console.log(`Node server listening on http://localhost:${PORT}`); | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment