Pending Flash

Loading "Pending Flash"
πŸ‘¨β€πŸ’Ό When the user's on a reasonably fast connection, getting the ship data doesn't take very long and as a result the loading state doesn't show up for all that long. This is great, except it results in a flash of the loading state while the ship takes ~50ms to load. It's jarring for the user and it would be better if we could avoid it.
We thought about adding a CSS delay of 300ms on the opacity transition, but that would just mean the flash of loading state happens for people for whom the data loading takes 350ms or so. Just moving the problem πŸ€·β€β™‚οΈ
What we really need is something that can give us the following experience:
  • If the loading takes less than 300ms, don't show a loading spinner at all.
  • If the loading takes longer than 300ms, show a loading spinner for at least 350ms. Even if the loading is shorter than 300ms + 350ms.
This way, if the user has a reasonably fast connection, they won't see a loading state at all, and if they have a medium fast connection, they'll be guaranteed to not get a flash of loading state because the loading state will show up for at least 350ms.
Luckily, there's a simple package that does exactly this: spin-delay. Here's an example:
import { useSpinDelay } from 'spin-delay'

function MyComponent() {
	const data = use(somePromise)
	const [isPending, startTransition] = useTransition()

	// options are optional, and default to these values
	const showSpinner = useSpinDelay(isPending, { delay: 500, minDuration: 200 })

	if (showSpinner) {
		return <Spinner />
	}

	// ...
}
So let's add this with a delay of 300 and a minDuration of 350 to the Ship component.
To test this experience out, you can update the getShip call with a second argument which is a delay that will ensure the request takes at least that amount of time (it's not super precise, but it should give you an idea).
Login to get access to the exclusive discord channel.
  • General
    How to run tests in IDE?
    anonymousBlack10:
    Is it possible to run the tests from the IDE or are they setup to be run just from the browser? Some...
    • βœ…1
    1 Β· 10 days ago
  • πŸ”€Suspense
    ⚑Performance
    How you can implement the delay transition in react router dom
    Lloren πŸš€:
    How i can use the delay spinner and useTransition hook on react routes im trying but i cant do i h...
    • βœ…1
    8 Β· 14 days ago
  • πŸ”€Suspense
    [QUESTION] Optimizations > Parallel Loading Workshop
    Ric πŸš€:
    I'm going through the Suspense workshop and in the last part I struggled a bit with one of the optim...
    • βœ…1
    1 Β· 17 days ago
  • 🎣Hooks
    πŸ”€Suspense
    Clarification on how to trigger a suspense
    seven πŸš€:
    Hello, in lesson about useTransition Kent said that "anytime you have a state update thats going to ...
    • βœ…1
    3 Β· 2 months ago
  • General
    Welcome to EpicReact.dev! Say Hello πŸ‘‹
    Kent C. Dodds β—† πŸš€πŸ†πŸŒŒ:
    Welcome to the first of many posts in the EpicReact.dev channel! Take a moment to introduce yourself...
    • πŸš€6
    49 Β· 2 days ago
  • General
    Launch editor error: spawn code ENOENT
    Andrew Elans 🌌 πŸš€:
    Clicking index.html gives this error in VS Code. Both from Chrome and Safari. Anyone?
    • βœ…2
    6 Β· 3 months ago
  • General
    Launch editor error: Could not open 'index.html' from:'playground' in the editor.
    Japhet πŸš€ πŸ† 🌌:
    I'm encountering an issue when trying to open a link from the file list. The error message I receive...
    • βœ…1
    15 Β· 3 months ago
  • πŸ”€Suspense
    Suspense img tip
    Jon Winsley πŸš€:
    The solution for Suspense Img/Img Component wasn't working for me, and it took a little bit to figur...
    • πŸ™Œ3
    5 Β· 3 months ago
  • General
    AI Assistant?
    John πŸš€:
    Kent has mentioned an AI assistant that he's using in VSCode. Is there any detail on what that is an...
    • βœ…2
    2 Β· 2 months ago
  • General
    Script to save playground folder
    larissapissurno πŸš€:
    Hi all, I personally like to take notes on the playground files, so in order to not lose this notes ...
    • βœ…1
    2 Β· 2 months ago
  • General
    Runninng Learning app on iPad?
    marcus_polonus πŸš€ 🌌:
    Hi all, Did anyone managed to setup learning app on iPad? I tried to use codesandbox, but when I am...
    • βœ…1
    1 Β· 3 months ago
  • General
    βš›οΈFundamentals
    Error boundary good practice
    Lloren πŸš€:
    I have always wondered if the error boundary is there a limit of error boundary that you can impleme...
    • βœ…1
    1 Β· 2 months ago
  • General
    Received this error when running the setup script for React Fundamentals
    ChrisP πŸš€:
    Hey guys, I am completely blocked at the moment. When I clone and run the setup for react fundamenta...
    • βœ…1
    2 Β· 3 months ago
  • General
    Unexpected server error (workshop-app does not load onboarding step)
    Matias 🌌 πŸš€:
    Hey! πŸ‘‹ I installed the free workshop "Build React Hooks" last week with no issues. Yesterday, whe...
    • βœ…1
    3 Β· 3 months ago
  • General
    Eye opening moment in 05/06 (β€žsatisfiesβ€œ operator of typescript)
    Chrigi πŸš€:
    Up until today I was not aware that having the type annotation on a variable is actually a type-cast...
    • πŸ™Œ2
    • βœ…1
    2 Β· 3 months ago
  • General
    Failed to fetch dynamically imported module...
    FacuPerezM 🌌:
    I am getting this error out of nowhere, in the 'test' tab inside the Workshop app. ``` Failed to f...
    • βœ…1
    3 Β· 3 months ago
  • General
    Epicshop not saving the video resolution
    Toni πŸš€ 🌌:
    Playback speed and caption settings are saved, but the video resolution always defaults to auto. Is ...
    • βœ…1
    7 Β· 3 months ago
  • General
    Clicking an exercise file launch VIM instead of VS Code
    DBattou πŸš€:
    I started going through the workshops, everything is setup and working fine except for opening a fil...
    • βœ…1
    2 Β· 3 months ago