import type { DocumentContext, DocumentInitialProps } from "next/document"; import Document from "next/document"; import { ServerStyleSheet, StyleSheetManager } from "styled-components"; import stylisRTLPlugin from "stylis-plugin-rtl"; export default 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(); } } }