How to set fallback with useSWRInfinite? #1895
-
Hi everybody, I hope that someone can help me here. I'm using Next with SSR and SSG, and for the normal useSWR hook I set all the initial data returning the props with the fallback object like this: return {
props: {
fallback: {
[unstable_serialize(key)]: data
}
} And then, in the _app file, I wrap the page components with the SWRConfig provider so the fallback data is set for every page, like this: const {fallback, ...restProps} = pageProps
<SWRConfig
value={{
fallback: fallback ?? {},
}}
>
<Component {...restProps} />
</SWRConfig> This is working and I have no problem at all. But I'm using now this useSWRInfinite hook, and the initial data is not getting loaded. I've tried returning the fallback like this: and neither of them work. The keys are the same, so it should get the initial data. |
Beta Was this translation helpful? Give feedback.
Replies: 3 comments 1 reply
-
I'm also having the same issue.
But this is not working for me neither UPDATE: I did work now, my issue was that I was overriding the SWR config. This is what it worked for me:
And in my useSWRInfinite file:
|
Beta Was this translation helpful? Give feedback.
-
@luigi-derson's answer worked for me as well. 👍 However, in the event that the key is an object, which was my case, it needs to be converted to a string in the same format that SWR uses. Here is how to do that for the fallback: ...
import { stableHash } from 'swr/_internal';
...
const keyObject = {...}
[unstable_serialize((size, prevData) => stableHash(keyObject))]: data |
Beta Was this translation helpful? Give feedback.
-
Thanks. This massively helped me with a problem I was having loading fallback data. Either I could set the data (an empty array) in the hook options and not have anything visible on the frontend, OR I could set the data via the Thanks again 🍺 |
Beta Was this translation helpful? Give feedback.
I'm also having the same issue.
unstable_serialize
should be imported fromswr/infinite
I think, which means it accepts a getKey function as parameter:[unstable_serialize((size, prevData) => ['your', 'key', size ] )]: data
or[data]
? Docs are not clear for swr/infinite caseBut this is not working for me neither
UPDATE:
@ramirezsandin FYI
I did work now, my issue was that I was overriding the SWR config.
This is what it worked for me:
[unstable_serialize((size) => ['your', 'key', size ] )]: [data]
And in my useSWRInfinite file:
const swr = useSWRInfinite((key) => ['your', 'key', size ], fetcher, config)