import ReactDOMServer from 'react-dom/server' import { SSRProvider } from '@react-aria/ssr' import { StaticRouter } from 'react-router-dom' import i18next from './locales/i18n' import { AppFr } from './entry-fr' import { AppEn } from './entry-en' import { ServerStyleSheet, StyleSheetManager } from 'styled-components' import { FilledContext, HelmetProvider } from 'react-helmet-async' export function render(url: string, lang: 'fr' | 'en') { const sheet = new ServerStyleSheet() const helmetContext = {} as FilledContext const App = lang === 'fr' ? AppFr : AppEn i18next.changeLanguage(lang).catch((err) => // eslint-disable-next-line no-console console.error(err) ) const element = ( ) // first render ReactDOMServer.renderToString(element) // second render with the configured engine const html = ReactDOMServer.renderToString(element) const styleTags = sheet.getStyleTags() return { html, styleTags, helmet: helmetContext.helmet } }