useGetListLive
This Enterprise Edition hook, alternative to useGetList
, subscribes to live updates on the record list.
Usage
import { useGetListLive } from '@react-admin/ra-realtime';
const LatestNews = () => {
const { data, total, isLoading, error } = useGetListLive('posts', {
pagination: { page: 1, perPage: 10 },
sort: { field: 'published_at', order: 'DESC' },
});
if (isLoading) {
return <Loading />;
}
if (error) {
return <p>ERROR</p>;
}
return (
<ul>
{data.map(item => (
<li key={item.id}>{item.title}</li>
))}
</ul>
);
};
The hook will subscribe to live updates on the list of records (topic: resource/[resource]
) and will refetch the list when a new record is created, or an existing record is updated or deleted.
See the useGetList
documentation for the full list of parameters and return type.
TypeScript
The useGetListLive
hook accepts a generic parameter for the record type:
import { useGetListLive } from '@react-admin/ra-realtime';
type Post = {
id: number;
title: string;
};
const LatestNews = () => {
const { data: posts, total, isLoading, error } = useGetListLive<Post>(
'posts',
{
pagination: { page: 1, perPage: 10 },
sort: { field: 'published_at', order: 'DESC' }
}
);
if (isLoading) { return <Loading />; }
if (error) { return <p>ERROR</p>; }
return (
<>
<h1>Latest news</h1>
<ul>
{/* TypeScript knows that posts is of type Post[] */}
{posts.map(post =>
<li key={post.id}>{post.title}</li>
)}
</ul>
<p>{posts.length} / {total} articles</p>
</>
);
};