|
|
@ -33,7 +33,6 @@ async function createDevRouter() {
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
r.use(vite.middlewares)
|
|
|
|
r.use(vite.middlewares)
|
|
|
|
|
|
|
|
|
|
|
|
r.use('*', async (req, res, next) => {
|
|
|
|
r.use('*', async (req, res, next) => {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
const indexHtml = await fs.readFile(path.resolve('./index.html'), 'utf-8')
|
|
|
|
const indexHtml = await fs.readFile(path.resolve('./index.html'), 'utf-8')
|
|
|
@ -47,8 +46,12 @@ async function createDevRouter() {
|
|
|
|
const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`
|
|
|
|
const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`
|
|
|
|
const metaTagsHtml =
|
|
|
|
const metaTagsHtml =
|
|
|
|
'' +
|
|
|
|
'' +
|
|
|
|
(metadata.title ? `<meta property="og:title" content="${metadata.title}" />\n` : '') +
|
|
|
|
(metadata.title ? `<meta property="og:title" content="${metadata.title ?? 'PHC | Problemi'}" />\n` : '') +
|
|
|
|
(metadata.description ? `<meta property="og:description" content="${metadata.description}" />\n` : '') +
|
|
|
|
(metadata.description
|
|
|
|
|
|
|
|
? `<meta property="og:description" content="${
|
|
|
|
|
|
|
|
metadata.description ?? 'Bacheca di problemi di matematica creato dal PHC'
|
|
|
|
|
|
|
|
}" />\n`
|
|
|
|
|
|
|
|
: '') +
|
|
|
|
`<meta property="og:url" content="${fullUrl}" />\n`
|
|
|
|
`<meta property="og:url" content="${fullUrl}" />\n`
|
|
|
|
|
|
|
|
|
|
|
|
res.send(transformedTemplate.replace('<!-- INJECT META TAGS -->', metaTagsHtml).replace('<!-- SSR OUTLET -->', html))
|
|
|
|
res.send(transformedTemplate.replace('<!-- INJECT META TAGS -->', metaTagsHtml).replace('<!-- SSR OUTLET -->', html))
|
|
|
@ -69,26 +72,37 @@ async function createProductionRouter() {
|
|
|
|
|
|
|
|
|
|
|
|
const r = express.Router()
|
|
|
|
const r = express.Router()
|
|
|
|
|
|
|
|
|
|
|
|
r.use('/', express.static('dist/entry-client'))
|
|
|
|
const handleSSR = async (req, res) => {
|
|
|
|
|
|
|
|
|
|
|
|
r.use('*', async (req, res) => {
|
|
|
|
|
|
|
|
const transformedTemplate = await fs.readFile(path.resolve('./dist/entry-client/index.html'), 'utf-8')
|
|
|
|
const transformedTemplate = await fs.readFile(path.resolve('./dist/entry-client/index.html'), 'utf-8')
|
|
|
|
|
|
|
|
|
|
|
|
const { html, metadata } = render(req.originalUrl)
|
|
|
|
const { html, metadata } = render(req.originalUrl)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
console.dir(transformedTemplate, { depth: null })
|
|
|
|
|
|
|
|
console.dir(html, { depth: null })
|
|
|
|
|
|
|
|
console.dir(metadata, { depth: null })
|
|
|
|
|
|
|
|
|
|
|
|
const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`
|
|
|
|
const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`
|
|
|
|
const metaTagsHtml =
|
|
|
|
const metaTagsHtml =
|
|
|
|
'' +
|
|
|
|
'' +
|
|
|
|
(metadata.title ? `<meta property="og:title" content="${metadata.title ?? 'PHC | Problemi'}" />\n` : '') +
|
|
|
|
(metadata.title
|
|
|
|
|
|
|
|
? `<meta property="og:title" content="${metadata.title}" />\n`
|
|
|
|
|
|
|
|
: `<meta property="og:title" content="PHC | Problemi" />\n`) +
|
|
|
|
(metadata.description
|
|
|
|
(metadata.description
|
|
|
|
? `<meta property="og:description" content="${
|
|
|
|
? `<meta property="og:description" content="${metadata.description}" />\n`
|
|
|
|
metadata.description ?? 'Bacheca di problemi di matematica creato dal PHC'
|
|
|
|
: `<meta property="og:description" content="Bacheca di problemi di matematica creato dal PHC" />\n`) +
|
|
|
|
}" />\n`
|
|
|
|
|
|
|
|
: '') +
|
|
|
|
|
|
|
|
`<meta property="og:url" content="${fullUrl}" />\n`
|
|
|
|
`<meta property="og:url" content="${fullUrl}" />\n`
|
|
|
|
|
|
|
|
|
|
|
|
res.send(transformedTemplate.replace('<!-- INJECT META TAGS -->', metaTagsHtml).replace('<!-- SSR OUTLET -->', html))
|
|
|
|
const finalHtml = transformedTemplate.replace('<!-- INJECT META TAGS -->', metaTagsHtml).replace('<!-- SSR OUTLET -->', html)
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
console.dir(finalHtml, { depth: null })
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
res.send(finalHtml)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
r.get('/', handleSSR)
|
|
|
|
|
|
|
|
r.use('/', express.static('dist/entry-client'))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
r.use('*', handleSSR)
|
|
|
|
|
|
|
|
|
|
|
|
return r
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
}
|
|
|
|