57 lines
1.7 KiB
TypeScript
57 lines
1.7 KiB
TypeScript
// IMPORTANT: DOM polyfill must be imported FIRST, before any browser-dependent libraries
|
|
import './src/ssr-dom-polyfill';
|
|
|
|
import { APP_BASE_HREF } from '@angular/common';
|
|
import { AngularNodeAppEngine, createNodeRequestHandler, writeResponseToNodeResponse } from '@angular/ssr/node';
|
|
import express from 'express';
|
|
import { fileURLToPath } from 'node:url';
|
|
import { dirname, join, resolve } from 'node:path';
|
|
|
|
// The Express app is exported so that it can be used by serverless Functions.
|
|
export function app(): express.Express {
|
|
const server = express();
|
|
const serverDistFolder = dirname(fileURLToPath(import.meta.url));
|
|
const browserDistFolder = resolve(serverDistFolder, '../browser');
|
|
const indexHtml = join(serverDistFolder, 'index.server.html');
|
|
|
|
const angularApp = new AngularNodeAppEngine();
|
|
|
|
server.set('view engine', 'html');
|
|
server.set('views', browserDistFolder);
|
|
|
|
// Example Express Rest API endpoints
|
|
// server.get('/api/**', (req, res) => { });
|
|
// Serve static files from /browser
|
|
server.get('*.*', express.static(browserDistFolder, {
|
|
maxAge: '1y'
|
|
}));
|
|
|
|
// All regular routes use the Angular engine
|
|
server.get('*', (req, res, next) => {
|
|
angularApp
|
|
.handle(req)
|
|
.then((response) => {
|
|
if (response) {
|
|
writeResponseToNodeResponse(response, res);
|
|
} else {
|
|
res.sendStatus(404);
|
|
}
|
|
})
|
|
.catch((err) => next(err));
|
|
});
|
|
|
|
return server;
|
|
}
|
|
|
|
function run(): void {
|
|
const port = process.env['PORT'] || 4200;
|
|
|
|
// Start up the Node server
|
|
const server = app();
|
|
server.listen(port, () => {
|
|
console.log(`Node Express server listening on http://localhost:${port}`);
|
|
});
|
|
}
|
|
|
|
run();
|