Skip to content

Commit

Permalink
Revert "Introduce better debug error handling (vercel#1590)" (vercel#…
Browse files Browse the repository at this point in the history
…1591)

This reverts commit 0bdd321.
  • Loading branch information
arunoda authored and rauchg committed Apr 1, 2017
1 parent 0bdd321 commit 87ff667
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 58 deletions.
49 changes: 11 additions & 38 deletions client/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import { createRouter } from '../lib/router'
import App from '../lib/app'
import evalScript from '../lib/eval-script'
import { loadGetInitialProps, getURL } from '../lib/utils'
import ErrorDebugComponent from '../lib/error-debug'

// Polyfill Promise globally
// This is needed because Webpack2's dynamic loading(common chunks) code
Expand Down Expand Up @@ -40,57 +39,33 @@ export const router = createRouter(pathname, query, getURL(), {
})

const headManager = new HeadManager()
const appContainer = document.getElementById('__next')
const errorContainer = document.getElementById('__next-error')
const container = document.getElementById('__next')

export default () => {
export default (onError) => {
const emitter = mitt()

router.subscribe(({ Component, props, hash, err }) => {
render({ Component, props, err, hash, emitter })
render({ Component, props, err, hash, emitter }, onError)
})

const hash = location.hash.substring(1)
render({ Component, props, hash, err, emitter })
render({ Component, props, hash, err, emitter }, onError)

return emitter
}

export async function render (props) {
if (props.err) {
await renderError(props.err)
return
}

export async function render (props, onError = renderErrorComponent) {
try {
await doRender(props)
} catch (err) {
if (err.abort) return
await renderError(err)
await onError(err)
}
}

// This method handles all runtime and debug errors.
// 404 and 500 errors are special kind of errors
// and they are still handle via the main render method.
export async function renderError (error) {
const prod = process.env.NODE_ENV === 'production'
// We need to unmount the current app component because it's
// in the inconsistant state.
// Otherwise, we need to face issues when the issue is fixed and
// it's get notified via HMR
ReactDOM.unmountComponentAtNode(appContainer)

const errorMessage = `${error.message}\n${error.stack}`
console.error(errorMessage)

if (prod) {
const initProps = { err: error, pathname, query }
const props = await loadGetInitialProps(ErrorComponent, initProps)
ReactDOM.render(createElement(ErrorComponent, props), errorContainer)
} else {
ReactDOM.render(createElement(ErrorDebugComponent, { error }), errorContainer)
}
async function renderErrorComponent (err) {
const { pathname, query } = router
const props = await loadGetInitialProps(ErrorComponent, { err, pathname, query })
await doRender({ Component: ErrorComponent, props, err })
}

async function doRender ({ Component, props, hash, err, emitter }) {
Expand All @@ -113,9 +88,7 @@ async function doRender ({ Component, props, hash, err, emitter }) {
// lastAppProps has to be set before ReactDom.render to account for ReactDom throwing an error.
lastAppProps = appProps

// We need to clear any existing runtime error messages
ReactDOM.unmountComponentAtNode(errorContainer)
ReactDOM.render(createElement(App, appProps), appContainer)
ReactDOM.render(createElement(App, appProps), container)

if (emitter) {
emitter.emit('after-reactdom-render', { Component })
Expand Down
19 changes: 6 additions & 13 deletions client/next-dev.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import evalScript from '../lib/eval-script'
import ReactReconciler from 'react-dom/lib/ReactReconciler'

const { __NEXT_DATA__: { errorComponent } } = window
const ErrorComponent = evalScript(errorComponent).default
Expand All @@ -8,18 +7,12 @@ require('react-hot-loader/patch')

const next = window.next = require('./')

const emitter = next.default()

// This is a patch to catch most of the errors throw inside React components.
const originalMountComponent = ReactReconciler.mountComponent
ReactReconciler.mountComponent = function (...args) {
try {
return originalMountComponent(...args)
} catch (err) {
next.renderError(err)
err.abort = true
throw err
}
const emitter = next.default(onError)

function onError (err) {
// just show the debug screen but don't render ErrorComponent
// so that the current component doesn't lose props
next.render({ err, emitter })
}

let lastScroll
Expand Down
3 changes: 2 additions & 1 deletion lib/app.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export default class App extends Component {
}

render () {
const { Component, props, hash, router } = this.props
const { Component, props, hash, err, router } = this.props
const url = createUrl(router)
// If there no component exported we can't proceed.
// We'll tackle that here.
Expand All @@ -28,6 +28,7 @@ export default class App extends Component {

return <div>
<Container {...containerProps} />
{ErrorDebug && err ? <ErrorDebug error={err} /> : null}
</div>
}
}
Expand Down
7 changes: 1 addition & 6 deletions server/document.js
Original file line number Diff line number Diff line change
Expand Up @@ -50,12 +50,7 @@ export class Main extends Component {

render () {
const { html } = this.context._documentProps
return (
<div>
<div id='__next' dangerouslySetInnerHTML={{ __html: html }} />
<div id='__next-error' />
</div>
)
return <div id='__next' dangerouslySetInnerHTML={{ __html: html }} />
}
}

Expand Down

0 comments on commit 87ff667

Please sign in to comment.