import Document, { Html, Head, Main, NextScript, DocumentContext, DocumentInitialProps, } from "next/document"; import { ServerStyleSheet } from "styled-components"; import { SeoTags } from "src/components/SeoTags"; class MyDocument extends Document { static async getInitialProps(ctx: DocumentContext): Promise { const sheet = new ServerStyleSheet(); const originalRenderPage = ctx.renderPage; try { ctx.renderPage = () => originalRenderPage({ enhanceApp: App => props => sheet.collectStyles(), }); const initialProps = await Document.getInitialProps(ctx); return { ...initialProps, styles: ( <> {initialProps.styles} {sheet.getStyleElement()} ), }; } finally { sheet.seal(); } } render() { return (
); } } export default MyDocument;