next.js/test/development/app-dir/react-performance-track/app/ReactServerRequests.tsx
ReactServerRequests.tsx47 lines1.2 KB
'use client'

import { useSyncExternalStore } from 'react'

const reactServerRequestsServerSnapshot: never[] = []
const ServerRequestsStore = {
  subscribe:
    typeof window === 'undefined'
      ? () => () => {}
      : window.reactServerRequests.subscribe,
  getSnapshot:
    typeof window === 'undefined'
      ? () => []
      : window.reactServerRequests.getStoreSnapshot,
  getServerSnapshot: () => reactServerRequestsServerSnapshot,
}

export function ReactServerRequests() {
  const reactServerRequests = useSyncExternalStore(
    ServerRequestsStore.subscribe,
    ServerRequestsStore.getSnapshot,
    ServerRequestsStore.getServerSnapshot
  )

  return (
    <>
      <p>{reactServerRequests.length} Server Request entries</p>
      <ol>
        {reactServerRequests.map((request, index) => (
          <li key={index}>
            <details>
              <summary>
                <strong>
                  {request.type}: {request.name || '<Unnamed>'}
                </strong>
                ({Math.round(request.startTime)}ms–
                {Math.round(request.endTime)}ms)
              </summary>
              <pre>{JSON.stringify(request.properties, null, 2)}</pre>
            </details>
          </li>
        ))}
      </ol>
    </>
  )
}
Quest for Codev2.0.0
/
SIGN IN