5. Adding Delete Feature
useDelete
is a Refine hook that is used to delete a record. It returns mutation functions that can be used to delete a record, and when the mutation function is called, the parameters of the function are passed to the delete
method of the data provider.
We will now add a delete button to the list page by using the useDelete
hook; for this, follow these steps:
Open the
src/pages/blog-posts/list.tsx
file on your editor.Import the
useOne
hook from@refinedev/core
:import { useOne } from "@refinedev/core";
Call the
useDelete
hook in theBlogPostList
component:const BlogPostList: React.FC = () => {
const { mutate: deleteBlogPost } = useDelete();
};You can check the parameters of the
deleteBlogPost
mutation function in theuseDelete
documentation.Add the
<button/>
component to theactions
column of the table as shown below:{
id: "actions",
accessorKey: "id",
header: "Actions",
cell: function render({ getValue }) {
return (
<div
style={{
display: "flex",
flexDirection: "row",
flexWrap: "wrap",
gap: "4px",
}}
>
<button
onClick={() => {
show("blog_posts", getValue() as string);
}}
>
Show
</button>
<button
onClick={() => {
edit("blog_posts", getValue() as string);
}}
>
Edit
</button>
<button
onClick={() => {
deleteBlogPost({
resource: "blog_posts",
id: getValue() as string,
});
}}
>
Delete
</button>
</div>
);
},
},
You can now delete a record from the list page by clicking on the delete button of any blog post.
You can also use useDelete
hook provided by Refine to delete a record.
For more information, refer to the useDelete
documentation→