import { renderToString as renderToString_ } from '@vue/server-renderer' import { escapeInject, dangerouslySkipEscape } from 'vike/server' import { PageContext, PageContextServer } from 'vike/types' import logoUrl from '#assets/favicon.ico' import image from '#assets/it4c-logo2-clean-bg_alpha-128x128.png' import { META } from '#src/env' import { createApp } from './app' import { getDescription, getTitle } from './utils' import type { App } from 'vue' async function render(pageContext: PageContextServer & PageContext) { const { app, i18n } = createApp(pageContext, false) const locale = i18n.global.locale.value const appHtml = await renderToString(app) // See https://vike.dev/head const title = getTitle(pageContext) const description = getDescription(pageContext) const documentHtml = escapeInject` ${title}
${dangerouslySkipEscape(appHtml)}
` return { documentHtml, pageContext: { // We can add some `pageContext` here, which is useful if we want to do page redirection https://vike.dev/page-redirection }, } } async function renderToString(app: App) { let err: unknown // Workaround: renderToString_() swallows errors in production, see https://github.com/vuejs/core/issues/7876 app.config.errorHandler = (err_) => { err = err_ } const appHtml = await renderToString_(app) if (err) throw err return appHtml } export default render