Spaces:
Paused
Paused
File size: 1,519 Bytes
a0fda44 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
import useSocket from "./useSocket";
import useSendMessage from "./useSendMessage";
const useChatBot = () => {
const { socketEmit } = useSocket();
const { sendMessage } = useSendMessage();
const extractTextFromHtml = (html) => {
// Fake html to get message text content
const fakeDiv = document.createElement("div");
fakeDiv.innerHTML = html;
return fakeDiv.textContent;
};
const getResponseFromChatBot = async ({ chatRoomId, userMessage }) => {
const message = extractTextFromHtml(userMessage);
// Send request
const request = await fetch(process.env.REACT_APP_BOT_URL, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
application: process.env.REACT_APP_BOT_APPLICATION_ID,
instance: process.env.REACT_APP_BOT_APPLICATION_INSTANCE,
message: message,
}),
});
const botReply = await request.json();
// Emit robot typing event
socketEmit("user:typing", chatRoomId, process.env.REACT_APP_BOT_ID);
// Send message back to user
sendMessage({
chatRoomId,
botMessage: botReply.message,
botId: process.env.REACT_APP_BOT_ID,
});
};
const respondAsChatBot = ({ chatRoomId, message }) => {
// Send message back to user
sendMessage({
chatRoomId,
botMessage: message,
botId: process.env.REACT_APP_BOT_ID,
});
};
return { getResponseFromChatBot, respondAsChatBot };
};
export default useChatBot;
|