mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-08 19:21:55 +00:00
f4bef24429
Fixed default renderer for react error boundary GitOrigin-RevId: 87f7d80385717db6c0222cd97ad373760c4e161c
35 lines
936 B
JavaScript
35 lines
936 B
JavaScript
import React from 'react'
|
|
import { ErrorBoundary } from 'react-error-boundary'
|
|
|
|
function errorHandler(error, componentStack) {
|
|
if (window.Raven) {
|
|
Raven.captureException(error, {
|
|
extra: { componentStack },
|
|
tags: { mechanism: 'react-error-boundary' }
|
|
})
|
|
}
|
|
}
|
|
|
|
function DefaultFallbackComponent() {
|
|
return <></>
|
|
}
|
|
|
|
function withErrorBoundary(WrappedComponent, FallbackComponent) {
|
|
function ErrorBoundaryWrapper(props) {
|
|
return (
|
|
<ErrorBoundary
|
|
FallbackComponent={FallbackComponent || DefaultFallbackComponent}
|
|
onError={errorHandler}
|
|
>
|
|
<WrappedComponent {...props} />
|
|
</ErrorBoundary>
|
|
)
|
|
}
|
|
ErrorBoundaryWrapper.propTypes = WrappedComponent.propTypes
|
|
ErrorBoundaryWrapper.displayName = `WithErrorBoundaryWrapper${WrappedComponent.displayName ||
|
|
WrappedComponent.name ||
|
|
'Component'}`
|
|
return ErrorBoundaryWrapper
|
|
}
|
|
|
|
export default withErrorBoundary
|