-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
v2: remove CatchBoundary + v2_errorBoundary (#6906)
- Loading branch information
1 parent
e3f2d02
commit e18adb9
Showing
64 changed files
with
1,034 additions
and
3,478 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
--- | ||
"@remix-run/dev": major | ||
"@remix-run/react": major | ||
"@remix-run/server-runtime": major | ||
"@remix-run/testing": major | ||
--- | ||
|
||
Remove `v2_errorBoundary` flag and `CatchBoundary` implementation |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,30 +1,55 @@ | ||
--- | ||
title: ErrorBoundary | ||
new: true | ||
--- | ||
|
||
# `ErrorBoundary` | ||
|
||
<docs-warning>The behaviors of `CatchBoundary` and `ErrorBoundary` are changing in v2. You can prepare for this change at your convenience with the `v2_errorBoundary` future flag. For instructions on making this change see the [v2 guide][v2guide].</docs-warning> | ||
A Remix `ErrorBoundary` component works just like normal React [error boundaries][error-boundaries], but with a few extra capabilities. When there is an error in your route component, the `ErrorBoundary` will be rendered in its place, nested inside any parent routes. `ErrorBoundary` components also render when there is an error in the `loader` or `action` functions for a route, so all errors for that route may be handled in one spot. | ||
|
||
An `ErrorBoundary` is a React component that renders whenever there is an error anywhere on the route, either during rendering or during data loading. We use the word "error" to mean an uncaught exception; something you didn't anticipate happening. You can intentionally throw a `Response` to render the `CatchBoundary`, but everything else that is thrown is handled by the `ErrorBoundary`. | ||
The most common use-cases tend to be: | ||
|
||
A Remix `ErrorBoundary` component works just like normal React [error boundaries][error-boundaries], but with a few extra capabilities. When there is an error in your route component, the `ErrorBoundary` will be rendered in its place, nested inside any parent routes. `ErrorBoundary` components also render when there is an error in the `loader` or `action` functions for a route, so all errors for that route may be handled in one spot. | ||
- You may intentionally throw a 4xx `Response` to trigger an error UI | ||
- Throwing a 400 on bad user input | ||
- Throwing a 401 for unauthorized access | ||
- Throwing a 404 when you can't find requested data | ||
- React may unintentionally throw an `Error` if it encounters a runtime error during rendering | ||
|
||
An `ErrorBoundary` component receives one prop: the `error` that occurred. | ||
To obtain the thrown object, you can use the [`useRouteError`][use-route-error] hook. When a `Response` is thrown, it will be automatically unwrapped into an `ErrorResponse` instance with `state`/`statusText`/`data` fields so that you don't need to bother with `await response.json()` in your component. To differentiate thrown `Response`'s from thrown `Error`'s' you can use the [`isRouteErrorResponse`][is-route-error-response] utility. | ||
|
||
```tsx | ||
export function ErrorBoundary({ error }) { | ||
return ( | ||
<div> | ||
<h1>Error</h1> | ||
<p>{error.message}</p> | ||
<p>The stack trace is:</p> | ||
<pre>{error.stack}</pre> | ||
</div> | ||
); | ||
import { | ||
isRouteErrorResponse, | ||
useRouteError, | ||
} from "@remix-run/react"; | ||
|
||
export function ErrorBoundary() { | ||
const error = useRouteError(); | ||
|
||
if (isRouteErrorResponse(error)) { | ||
return ( | ||
<div> | ||
<h1> | ||
{error.status} {error.statusText} | ||
</h1> | ||
<p>{error.data}</p> | ||
</div> | ||
); | ||
} else if (error instanceof Error) { | ||
return ( | ||
<div> | ||
<h1>Error</h1> | ||
<p>{error.message}</p> | ||
<p>The stack trace is:</p> | ||
<pre>{error.stack}</pre> | ||
</div> | ||
); | ||
} else { | ||
return <h1>Unknown Error</h1>; | ||
} | ||
} | ||
``` | ||
|
||
[error-boundaries]: https://reactjs.org/docs/error-boundaries.html | ||
[error-boundary-v2]: ./error-boundary-v2 | ||
[v2guide]: ../pages/v2#catchboundary-and-errorboundary | ||
[use-route-error]: ../hooks/use-route-error | ||
[is-route-error-response]: ../utils/is-route-error-response |
Oops, something went wrong.