LibreChat/client/src/components/Conversations/DeleteButton.jsx

31 lines
1,011 B
React
Raw Normal View History

2023-02-06 21:17:46 -05:00
import React from 'react';
import TrashIcon from '../svg/TrashIcon';
import CrossIcon from '../svg/CrossIcon';
import manualSWR from '~/utils/fetchers';
import { useRecoilValue } from 'recoil';
import store from '~/store';
export default function DeleteButton({ conversationId, renaming, cancelHandler, retainView }) {
const currentConversation = useRecoilValue(store.conversation) || {};
const { newConversation } = store.useConversation();
const { refreshConversations } = store.useConversations();
const { trigger } = manualSWR(`/api/convos/clear`, 'post', () => {
if (currentConversation?.conversationId == conversationId) newConversation();
refreshConversations();
retainView();
});
const clickHandler = () => trigger({ conversationId, source: 'button' });
const handler = renaming ? cancelHandler : clickHandler;
2023-02-06 21:17:46 -05:00
return (
<button
className="p-1 hover:text-white"
onClick={handler}
>
{renaming ? <CrossIcon /> : <TrashIcon />}
2023-02-06 21:17:46 -05:00
</button>
);
}