|
|
|
import { dirname, resolve } from 'path'
|
|
|
|
import express from 'express'
|
|
|
|
import { createServer as createViteServer } from 'vite'
|
|
|
|
import { fileURLToPath } from 'url'
|
|
|
|
import { readFile } from 'fs/promises'
|
|
|
|
|
|
|
|
import routes from './routes.js'
|
|
|
|
|
|
|
|
const __dirname = dirname(fileURLToPath(import.meta.url))
|
|
|
|
|
|
|
|
async function createServer(customHtmlRoutes) {
|
|
|
|
const app = express()
|
|
|
|
|
|
|
|
// In middleware mode, if you want to use Vite's own HTML serving logic
|
|
|
|
// use `'html'` as the `middlewareMode` (ref https://vitejs.dev/config/#server-middlewaremode)
|
|
|
|
const vite = await createViteServer({
|
|
|
|
server: { middlewareMode: 'html' },
|
|
|
|
})
|
|
|
|
|
|
|
|
for (const [route, file] of Object.entries(customHtmlRoutes)) {
|
|
|
|
app.get(route, async (req, res) => {
|
|
|
|
const filePath = resolve(__dirname, file)
|
|
|
|
console.log(`Custom Route: %s`, req.url)
|
|
|
|
|
|
|
|
const htmlFile = await readFile(filePath, 'utf8')
|
|
|
|
const htmlViteHooksFile = await vite.transformIndexHtml(req.originalUrl, htmlFile)
|
|
|
|
|
|
|
|
res.setHeader('Content-Type', 'text/html')
|
|
|
|
return res.send(htmlViteHooksFile)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
app.use(vite.middlewares)
|
|
|
|
|
|
|
|
app.listen(3000)
|
|
|
|
}
|
|
|
|
|
|
|
|
createServer(routes)
|