mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
import Document, { Head, Main, NextScript } from 'next/document'
|
|
import React from 'react'
|
|
import { AppRegistry } from 'react-native-web'
|
|
|
|
let index = 0
|
|
|
|
// Force Next-generated DOM elements to fill their parent's height.
|
|
// Not required for using of react-native-web, but helps normalize
|
|
// layout for top-level wrapping elements.
|
|
const normalizeNextElements = `
|
|
body > div:first-child,
|
|
#__next {
|
|
display: flex;
|
|
flex-direction: column;
|
|
height: 100%;
|
|
}
|
|
`
|
|
|
|
export default class MyDocument extends Document {
|
|
static async getInitialProps ({ renderPage }) {
|
|
AppRegistry.registerComponent('Main', () => Main)
|
|
const { getStyleElement } = AppRegistry.getApplication('Main')
|
|
const page = renderPage()
|
|
const styles = [
|
|
<style
|
|
key={index++}
|
|
dangerouslySetInnerHTML={{ __html: normalizeNextElements }}
|
|
/>,
|
|
getStyleElement()
|
|
]
|
|
return { ...page, styles }
|
|
}
|
|
|
|
render () {
|
|
return (
|
|
<html style={{ height: '100%', width: '100%' }}>
|
|
<Head>
|
|
<title>react-native-web</title>
|
|
<meta name='viewport' content='width=device-width, initial-scale=1' />
|
|
</Head>
|
|
<body style={{ height: '100%', width: '100%', overflowY: 'scroll' }}>
|
|
<Main />
|
|
<NextScript />
|
|
</body>
|
|
</html>
|
|
)
|
|
}
|
|
}
|