|
import { useEffect } from 'react' |
|
import Image from 'next/image' |
|
|
|
import IconWarning from '@/assets/images/warning.svg' |
|
import { ChatError, ErrorCode, ChatMessageModel } from '@/lib/bots/bing/types' |
|
import { ExternalLink } from './external-link' |
|
import { useBing } from '@/lib/hooks/use-bing' |
|
|
|
export interface ChatNotificationProps extends Pick<ReturnType<typeof useBing>, 'bot'> { |
|
message?: ChatMessageModel |
|
} |
|
|
|
function getAction(error: ChatError, reset: () => void) { |
|
if (error.code === ErrorCode.THROTTLE_LIMIT) { |
|
reset() |
|
return ( |
|
<div> |
|
你已达到每日最大发送消息次数,请<a href={`#dialog="settings"`}>更换账号</a>或隔一天后重试 |
|
</div> |
|
) |
|
} |
|
if (error.code === ErrorCode.BING_IP_FORBIDDEN) { |
|
return ( |
|
<ExternalLink href="https://github.com/weaigc/bingo/issues"> |
|
你的服务器或代理已被封禁,请更换服务器或使用代理重试 |
|
</ExternalLink> |
|
) |
|
} |
|
if (error.code === ErrorCode.BING_TRY_LATER) { |
|
return ( |
|
<ExternalLink href="/"> |
|
创建会话失败,请稍候重试 |
|
</ExternalLink> |
|
) |
|
} |
|
if (error.code === ErrorCode.BING_FORBIDDEN) { |
|
return ( |
|
<ExternalLink href="https://bing.com/new"> |
|
你的账号已在黑名单,请尝试更换账号及申请解封 |
|
</ExternalLink> |
|
) |
|
} |
|
if (error.code === ErrorCode.CONVERSATION_LIMIT) { |
|
return ( |
|
<div> |
|
当前话题已中止,请点 |
|
<a href={`#dialog="reset"`}>重新开始</a> |
|
开启新的对话 |
|
</div> |
|
) |
|
} |
|
if (error.code === ErrorCode.BING_CAPTCHA) { |
|
return ( |
|
<ExternalLink href="https://www.bing.com/turing/captcha/challenge"> |
|
点击通过人机验证 |
|
</ExternalLink> |
|
) |
|
} |
|
if (error.code === ErrorCode.BING_UNAUTHORIZED) { |
|
reset() |
|
return ( |
|
<a href={`#dialog="settings"`}>没有获取到身份信息或身份信息失效,点此重新设置</a> |
|
) |
|
} |
|
return error.message |
|
} |
|
|
|
export function ChatNotification({ message, bot }: ChatNotificationProps) { |
|
useEffect(() => { |
|
window.scrollBy(0, 2000) |
|
}, [message]) |
|
|
|
if (!message?.error) return |
|
|
|
return ( |
|
<div |
|
className="notification-container" |
|
> |
|
<div className="bottom-notifications"> |
|
<div className="inline-type with-decorative-line"> |
|
<div className="text-container mt-1"> |
|
<div className="title inline-flex items-start"> |
|
<Image alt="error" src={IconWarning} width={20} className="mr-1 mt-1" /> |
|
{getAction(message.error, () => bot.resetConversation())} |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
) |
|
} |
|
|