next.js/test/e2e/app-dir/navigation/app/not-found/suspense/page.js
page.js42 lines855 B
import { Suspense } from 'react'
import { notFound } from 'next/navigation'

function createSuspenseyComponent(Component, { timeout = 0, expire = 10 }) {
  let result
  let promise
  return function Data() {
    if (result) return result
    if (!promise)
      promise = new Promise((resolve) => {
        setTimeout(() => {
          result = <Component />
          setTimeout(() => {
            result = undefined
            promise = undefined
          }, expire)
          resolve()
        }, timeout)
      })
    throw promise
  }
}

function NotFound() {
  notFound()
  return <></>
}

const SuspenseyNotFound = createSuspenseyComponent(NotFound, {
  timeout: 300,
})

export default function () {
  return (
    <div className="suspense">
      <Suspense fallback="fallback">
        <SuspenseyNotFound />
      </Suspense>
    </div>
  )
}
Quest for Codev2.0.0
/
SIGN IN