* Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript (#265) * Trying a new github workflow to install javascript packages * Bump tailwindcss from 1.9.2 to 1.9.4 in /build/javascript (#266) Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 1.9.2 to 1.9.4. - [Release notes](https://github.com/tailwindlabs/tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/master/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.4) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript Bumps [preact](https://github.com/preactjs/preact) from 10.5.4 to 10.5.5. - [Release notes](https://github.com/preactjs/preact/releases) - [Commits](https://github.com/preactjs/preact/compare/10.5.4...10.5.5) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Owncast <owncast@owncast.online> * Bump @justinribeiro/lite-youtube in /build/javascript Bumps [@justinribeiro/lite-youtube](https://github.com/justinribeiro/lite-youtube) from 0.9.0 to 0.9.1. - [Release notes](https://github.com/justinribeiro/lite-youtube/releases) - [Commits](https://github.com/justinribeiro/lite-youtube/commits) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Owncast <owncast@owncast.online> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com>
44 lines
1.2 KiB
JavaScript
44 lines
1.2 KiB
JavaScript
// import { enqueueRender } from '../component';
|
|
|
|
/**
|
|
* Find the closest error boundary to a thrown error and call it
|
|
* @param {object} error The thrown value
|
|
* @param {import('../internal').VNode} vnode The vnode that threw
|
|
* the error that was caught (except for unmounting when this parameter
|
|
* is the highest parent that was being unmounted)
|
|
*/
|
|
export function _catchError(error, vnode) {
|
|
/** @type {import('../internal').Component} */
|
|
let component, ctor, handled;
|
|
|
|
const wasHydrating = vnode._hydrating;
|
|
|
|
for (; (vnode = vnode._parent); ) {
|
|
if ((component = vnode._component) && !component._processingException) {
|
|
try {
|
|
ctor = component.constructor;
|
|
|
|
if (ctor && ctor.getDerivedStateFromError != null) {
|
|
component.setState(ctor.getDerivedStateFromError(error));
|
|
handled = component._dirty;
|
|
}
|
|
|
|
if (component.componentDidCatch != null) {
|
|
component.componentDidCatch(error);
|
|
handled = component._dirty;
|
|
}
|
|
|
|
// This is an error boundary. Mark it as having bailed out, and whether it was mid-hydration.
|
|
if (handled) {
|
|
vnode._hydrating = wasHydrating;
|
|
return (component._pendingError = component);
|
|
}
|
|
} catch (e) {
|
|
error = e;
|
|
}
|
|
}
|
|
}
|
|
|
|
throw error;
|
|
}
|