2023-04-06 02:06:39 +08:00
|
|
|
import React, { useState } from 'react';
|
|
|
|
|
import { useRecoilValue } from 'recoil';
|
|
|
|
|
import { Download } from 'lucide-react';
|
|
|
|
|
import { cn } from '~/utils/';
|
|
|
|
|
|
|
|
|
|
import ExportModel from './ExportModel';
|
|
|
|
|
|
|
|
|
|
import store from '~/store';
|
|
|
|
|
|
|
|
|
|
export default function ExportConversation() {
|
|
|
|
|
const [open, setOpen] = useState(false);
|
|
|
|
|
|
|
|
|
|
const conversation = useRecoilValue(store.conversation) || {};
|
|
|
|
|
|
|
|
|
|
const exportable =
|
|
|
|
|
conversation?.conversationId &&
|
|
|
|
|
conversation?.conversationId !== 'new' &&
|
|
|
|
|
conversation?.conversationId !== 'search';
|
|
|
|
|
|
|
|
|
|
const clickHandler = () => {
|
|
|
|
|
if (exportable) setOpen(true);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<>
|
2023-04-07 19:25:30 +05:30
|
|
|
<button
|
2023-04-06 02:06:39 +08:00
|
|
|
className={cn(
|
2023-05-14 21:12:17 +05:30
|
|
|
'flex py-3 px-3 items-center gap-3 transition-colors duration-200 text-white cursor-pointer text-sm hover:bg-gray-700 w-full',
|
2023-04-06 02:06:39 +08:00
|
|
|
exportable ? 'cursor-pointer text-white' : 'cursor-not-allowed text-gray-400'
|
|
|
|
|
)}
|
|
|
|
|
onClick={clickHandler}
|
|
|
|
|
>
|
|
|
|
|
<Download size={16} />
|
|
|
|
|
Export conversation
|
2023-04-07 19:25:30 +05:30
|
|
|
</button>
|
2023-04-06 02:06:39 +08:00
|
|
|
|
|
|
|
|
<ExportModel
|
|
|
|
|
open={open}
|
|
|
|
|
onOpenChange={setOpen}
|
|
|
|
|
/>
|
|
|
|
|
</>
|
|
|
|
|
);
|
|
|
|
|
}
|