generated from arvinxx/npm-template
-
Notifications
You must be signed in to change notification settings - Fork 103
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
👑 [需求] 输入框的停止响应按钮可否增加一个事件回调 #296
Labels
enhancement
New feature or request
Comments
终止按钮的话,确实没有这个功能 但是有个 onChatEnd 的 api ,不知道能不能平替你这个场景 |
如果大家有多种类似需求,可以点 +1 ,后期给添加该功能 |
onChatEnd是在对话结束的时候触发,停止响应的时候不会触发 |
可以试试这个方案 interface State {
isSending: boolean
}
const YouComponent = () => {
const [state, setState] = useSetState<State>({
isSending: false
}); <ProChat
onChatStart={() => setState({isSending: true})}
onChatEnd={() => setState({isSending: false})}
sendButtonRender={(defaultDom, defaultButtonProps) => {
// 根据当前消息发送状态决定停止按钮的动作行为
const customOnClick = (event: React.MouseEvent<HTMLElement, MouseEvent>) => {
if (state.isSending) {
// 调用自己的function。比如:调用一个服务端接口,cancel掉服务端的异步任务,关闭SSE流
// notice: 不要忘记在拦截的动作最后也执行defaultButtonProps.onClick?.(event);,我这里是包裹在自己的cancelStream中了,因为我要等调用接口的Promise.then()
cancelStream(defaultButtonProps, event);
} else {
defaultButtonProps.onClick?.(event);
}
};
return <Button {...defaultButtonProps} onClick={customOnClick}/>;
}}
/> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
🥰 需求描述
目前是通过signal参数断开请求,但是我希望在点击终止按钮后调用服务接口。
🧐 解决方案
增加一个停止响应的回调
The text was updated successfully, but these errors were encountered: