@lxsmnsyc/react-fallback v0.1.0
@lxsmnsyc/react-fallback
Easy fallback UI handler for React
Install
npm install --save @lxsmnsyc/react-fallbackyarn add @lxsmnsyc/react-fallbackUsage
react-fallback aims to easily present fallback UI whenever the main UI fails. Managing Fallback UIs can be cumbersome and can lead to nested component trees.
FallbackBoundary
FallbackBoundary is a React component that manages the fallback UI for the component tree. The rendered content of a FallbackBoundary may throw a valid React element which will be switched in place of the currently rendered UI.
import { FallbackBoundary } from '@lxsmnsyc/react-fallback';
// ...
<FallbackBoundary>
<FallibleComponent />
</FallbackBoundary>Say, if we want to present the sign-in form if the user hasn't signed in yet, we may present the form inside the component.
if (notSignedIn) {
throw <SignIn />;
}Why throw instead of conditionally rendering the UI?
This is so that we can bail-out immediately of the render logic and so we can render the fallback immediately to prevent further effects to occur. For example, given that useSignInRequired and useMobileOnly throws a fallback UI:
useMobileOnly();
const credentials = useSignInRequired();
return (
<UserDetails credentials={credentials} />;
);We don't have to check the user's authentication if the UI is only for mobile. Due to the nature of React hooks, we can't call useSignInRequired in a conditional way without producing another layer of component tree.
useFallbackBoundaryRefresh
useFallbackBoundaryRefresh is a hook that provides a function you can call to refresh the nearest ancestor FallbackBoundary. If called without a valid React element as an argument, it will attempt to remount the children, otherwise, it will render the given element as a fallback UI.
const refresh = useFallbackBoundaryRefresh();
// User has signed out, refresh the boundary to remount.
const signOut = () => {
deleteCredentials();
refresh();
};License
MIT © lxsmnsyc
5 years ago