import Document, { Head, Main, NextScript } from 'next/document' import Helmet from 'react-helmet' export default class extends Document { static async getInitialProps ({ renderPage }) { // see https://github.com/nfl/react-helmet#server-usage for more information // 'head' was occupied by 'renderPage().head', we cannot use it return { ...renderPage(), helmet: Helmet.rewind() } } // should render on get helmetHtmlAttrComponents () { return this.props.helmet.htmlAttributes.toComponent() } // should render on get helmetHeadComponents () { return Object.keys(this.props.helmet) .filter(el => el !== 'htmlAttributes') // remove htmlAttributes which is not for but for .map(el => this.props.helmet[el].toComponent()) } get helmetJsx () { return () } render () { return ( { this.helmetJsx } { this.helmetHeadComponents }
) } }