Confused about revalidating data
Answered
Britannia Petite posted this in #help-forum
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
Hi folks,
I have a page implemented as a server component that provides data to a client component. The client component serves as the main page content and includes:
1. A settings form.
2. A separate section with a list of items (not part of the form).
The items in the list can be added, edited, or removed. To keep things simple, let's focus on the "delete" case. When a user clicks "delete," I call a server action to remove the item from the database. However, the item remains visible in the list until the page is refreshed.
My question is: how can I immediately remove the item from the list once the server action returns a success response? I’d like to avoid refreshing the entire page, as I don’t want to lose the state of the potentially unsaved form.
Thanks!
I have a page implemented as a server component that provides data to a client component. The client component serves as the main page content and includes:
1. A settings form.
2. A separate section with a list of items (not part of the form).
The items in the list can be added, edited, or removed. To keep things simple, let's focus on the "delete" case. When a user clicks "delete," I call a server action to remove the item from the database. However, the item remains visible in the list until the page is refreshed.
My question is: how can I immediately remove the item from the list once the server action returns a success response? I’d like to avoid refreshing the entire page, as I don’t want to lose the state of the potentially unsaved form.
Thanks!
32 Replies
import { revalidatePath } from 'next/cache'
revalidatePath('/blog/post-1')
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
Hi @gin , this does nothing in my case, not sure why. After action request nothing happens
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
what are u expecting to revalidate?
like a clientside state or what
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
It's a data from the server (component) passed to client component
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yeah that data will be revalidated
but the component will not rerender
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
hold on, revalidatePath should be called in action or in client component?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
only the data will mutate
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
🤦
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
check this
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
wohoo
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
'use server'
import { revalidatePath } from 'next/cache'
export default async function submit() {
await submitForm()
revalidatePath('/')
}
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Britannia PetiteOP
perfect!! TY
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
nice :)
ty
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Korat
@gin Im wondering how this work if the route is dynamic (case where we use next-intl)
do we do revalidatePath(/en|fr/.../...) ?
do we do revalidatePath(/en|fr/.../...) ?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Korat <@759064479521701888> Im wondering how this work if the route is dynamic (case where we use next-intl)
do we do revalidatePath(/en|fr/.../...) ?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
uhm if next-intl works with dynamic segments, u could try revalidating like this
revalidatePath('/(main)/[locale]', 'layout')
or only
revalidatePath('/[locale]', 'layout')
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Korat
are you saying [locale] works?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
u can try
im not sure
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Korat
ohh locale is a variable right?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yeah
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Korat
or no
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Korat
aight thanks for the suggestion