Skip to content

Instantly share code, notes, and snippets.

@corysimmons
Created January 29, 2024 04:07
Show Gist options
  • Save corysimmons/7502923bc0e78e021285acb41e184c21 to your computer and use it in GitHub Desktop.
Save corysimmons/7502923bc0e78e021285acb41e184c21 to your computer and use it in GitHub Desktop.
Just a hook to replace SWR and react-query in Next.js server components (Next.js' new `fetch` automatically handles caching and stuff). https://nextjs.org/docs/app/api-reference/functions/fetch
'use server';
import { useServerFetch } from '../hooks/useServerFetch';
export default async function Page() {
const { loading, error, data } = useServerFetch<any>('/api/123');
if (loading) return <h1>loading</h1>;
if (error) return <h1>{error.message}</h1>;
return <h1>{JSON.stringify(data)}</h1>;
}
// hooks/useServerFetch.ts
import { useEffect, useState } from 'react';
export function useServerFetch<T>(url: string) {
const [data, setData] = useState<T | null>(null);
const [loading, setLoading] = useState(true);
const [error, setError] = useState<Error | null>(null);
useEffect(() => {
async function fetchData() {
try {
const response = await fetch(url);
if (!response.ok) {
throw new Error(`Error fetching data: ${response.statusText}`);
}
const json = await response.json();
setData(json);
} catch (e) {
if (e instanceof Error) {
setError(e);
}
} finally {
setLoading(false);
}
}
fetchData();
}, [url]);
return { data, loading, error };
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment