Files
FastGPT/packages/web/components/common/MyPopover/PopoverConfirm.tsx
Archer 5fab3734fa Invoice (#2435)
* feat: invoice (#2293)

* feat: default voice header

* add i18n

* refactor: 优化代码

* feat: 用户开票

* refactor: 代码优化&&样式联调 (#2384)

* Feat: invoice upload (#2424)

* refactor: 验收问题&&样式调整

* feat: 文件上传

* 小调整

* perf: invoice ui

---------

Co-authored-by: papapatrick <109422393+Patrickill@users.noreply.github.com>
2024-08-19 17:44:48 +08:00

102 lines
2.4 KiB
TypeScript

import React, { useMemo } from 'react';
import { useTranslation } from 'next-i18next';
import MyIcon from '../Icon';
import { useRequest2 } from '../../../hooks/useRequest';
import {
Popover,
PopoverTrigger,
PopoverContent,
useDisclosure,
PlacementWithLogical,
HStack,
Box,
Button,
PopoverArrow
} from '@chakra-ui/react';
const PopoverConfirm = ({
content,
showCancel,
type,
Trigger,
placement = 'bottom-start',
offset,
onConfirm,
confirmText,
cancelText
}: {
content: string;
showCancel?: boolean;
type?: 'info' | 'delete';
Trigger: React.ReactNode;
placement?: PlacementWithLogical;
offset?: [number, number];
onConfirm: () => any;
confirmText?: string;
cancelText?: string;
}) => {
const { t } = useTranslation();
const map = useMemo(() => {
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, t]);
const firstFieldRef = React.useRef(null);
const { onOpen, onClose, isOpen } = useDisclosure();
const { runAsync: onclickConfirm, loading } = useRequest2(onConfirm, {
onSuccess: onClose
});
return (
<Popover
isOpen={isOpen}
initialFocusRef={firstFieldRef}
onOpen={onOpen}
onClose={onClose}
placement={placement}
offset={offset}
closeOnBlur={false}
trigger={'click'}
openDelay={100}
closeDelay={100}
isLazy
lazyBehavior="keepMounted"
arrowSize={10}
>
<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'}>{content}</Box>
</HStack>
<HStack mt={1} justifyContent={'flex-end'}>
{showCancel && (
<Button variant={'whiteBase'} size="sm" onClick={onClose}>
{cancelText || t('common:common.Cancel')}
</Button>
)}
<Button isLoading={loading} variant={map.variant} size="sm" onClick={onclickConfirm}>
{confirmText || t('common:common.Confirm')}
</Button>
</HStack>
</PopoverContent>
</Popover>
);
};
export default PopoverConfirm;