Files
FastGPT/packages/web/components/common/MyPopover/PopoverConfirm.tsx
T
heheer 09b9fa517b chat log soft delete (#6110)
* chat log soft delete

* perf: history api

* add history test

* Update packages/web/i18n/en/app.json

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* zod parse error

* fix: ts

---------

Co-authored-by: archer <545436317@qq.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-12-18 10:17:10 +08:00

122 lines
2.8 KiB
TypeScript

import React from 'react';
import { useTranslation } from 'next-i18next';
import MyIcon from '../Icon';
import { useRequest2 } from '../../../hooks/useRequest';
import {
Popover,
PopoverTrigger,
PopoverContent,
useDisclosure,
type PlacementWithLogical,
HStack,
Box,
Button,
PopoverArrow
} from '@chakra-ui/react';
import { useMemoEnhance } from '../../../hooks/useMemoEnhance';
const PopoverConfirm = ({
content,
showCancel = true,
type,
Trigger,
placement = 'auto',
offset,
onConfirm,
confirmText,
cancelText
}: {
content: string;
showCancel?: boolean;
type?: 'info' | 'delete';
Trigger: React.ReactNode;
placement?: PlacementWithLogical;
offset?: [number, number];
onConfirm: () => Promise<any> | any;
confirmText?: string;
cancelText?: string;
}) => {
const { t } = useTranslation();
const map = useMemoEnhance(() => {
const map = {
info: {
variant: 'primary',
icon: 'common/confirm/commonTip'
},
delete: {
variant: 'dangerFill',
icon: 'common/confirm/deleteTip'
}
};
if (type && map[type]) return map[type];
return map.info;
}, [type]);
const firstFieldRef = React.useRef(null);
const { onOpen, onClose, isOpen } = useDisclosure();
const { runAsync: onclickConfirm, loading } = useRequest2(async () => onConfirm(), {
onSuccess: onClose
});
return (
<Popover
isOpen={isOpen}
initialFocusRef={firstFieldRef}
onOpen={onOpen}
onClose={onClose}
placement={placement}
offset={offset}
closeOnBlur={true}
trigger={'click'}
openDelay={100}
closeDelay={100}
isLazy
lazyBehavior="unmount"
arrowSize={10}
strategy={'fixed'}
computePositionOnMount={true}
>
<PopoverTrigger>{Trigger}</PopoverTrigger>
<PopoverContent p={4}>
<PopoverArrow />
<HStack alignItems={'flex-start'} color={'myGray.700'}>
<MyIcon name={map.icon as any} w={'1.5rem'} />
<Box fontSize={'sm'} whiteSpace={'pre-wrap'}>
{content}
</Box>
</HStack>
<HStack mt={2} justifyContent={'flex-end'}>
{showCancel && (
<Button
variant={'whiteBase'}
size="sm"
onClick={(e) => {
e.stopPropagation();
onClose();
}}
>
{cancelText || t('common:Cancel')}
</Button>
)}
<Button
isLoading={loading}
variant={map.variant}
size="sm"
onClick={async (e) => {
e.stopPropagation();
await onclickConfirm();
}}
>
{confirmText || t('common:Confirm')}
</Button>
</HStack>
</PopoverContent>
</Popover>
);
};
export default PopoverConfirm;