diff --git a/frontend/package-lock.json b/frontend/package-lock.json index 8a0c145e..9e9d3e7b 100644 --- a/frontend/package-lock.json +++ b/frontend/package-lock.json @@ -11,6 +11,7 @@ "@testing-library/jest-dom": "^5.17.0", "@testing-library/react": "^13.4.0", "@testing-library/user-event": "^13.5.0", + "axios": "^1.6.7", "firebase": "^10.8.0", "react": "^18.2.0", "react-dom": "^18.2.0", @@ -5978,6 +5979,29 @@ "node": ">=4" } }, + "node_modules/axios": { + "version": "1.6.7", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz", + "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==", + "dependencies": { + "follow-redirects": "^1.15.4", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/axios/node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/axobject-query": { "version": "3.2.1", "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-3.2.1.tgz", @@ -15320,6 +15344,11 @@ "node": ">= 0.10" } }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + }, "node_modules/psl": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", diff --git a/frontend/package.json b/frontend/package.json index 27027bcd..c6216561 100644 --- a/frontend/package.json +++ b/frontend/package.json @@ -6,6 +6,7 @@ "@testing-library/jest-dom": "^5.17.0", "@testing-library/react": "^13.4.0", "@testing-library/user-event": "^13.5.0", + "axios": "^1.6.7", "firebase": "^10.8.0", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/frontend/src/components/Chats/Chats.js b/frontend/src/components/Chats/Chats.js index c1546b04..d77abfae 100644 --- a/frontend/src/components/Chats/Chats.js +++ b/frontend/src/components/Chats/Chats.js @@ -8,7 +8,7 @@ import { useSpeechSynthesis } from 'react-speech-kit'; import { useSpeechRecognition } from 'react-speech-recognition'; import { split } from 'sentence-splitter'; import SpeechRecognition from 'react-speech-recognition'; - +import axios from 'axios'; // Import Axios function Chats(props) { const [userName, setUserName] = useState(""); @@ -21,35 +21,28 @@ function Chats(props) { const [messages, setMessages] = useState([{ text: 'Hello, I am Chatbot', fromUser: false }]); const [input, setInput] = useState(''); const [isTyping, setIsTyping] = useState(false); + const [lastBotMessage, setLastBotMessage] = useState(null); const { speak } = useSpeechSynthesis(); const { transcript, listening } = useSpeechRecognition(); - const keyValuePairList = {}; // Define your key-value pairs - const fixedAnswers = {}; // Define your fixed answers + const predefinedAnswers = { + "What is your name?": "My name is Chatbot.", + // Define your predefined answers here + }; const handleUserInput = async () => { const userMessage = input.trim(); if (userMessage) { - if (keyValuePairList.hasOwnProperty(userMessage)) { - // Handle key-value pairs - const value = keyValuePairList[userMessage]; - setMessages((prevMessages) => [ - ...prevMessages, - { text: `${userMessage}`, fromUser: true }, - { text: `${value}`, fromUser: false }, - ]); - speak({ text: value }); - } else if (fixedAnswers.hasOwnProperty(userMessage)) { - // Handle predefined answers - const fixedAnswer = fixedAnswers[userMessage]; + if (predefinedAnswers.hasOwnProperty(userMessage)) { + const predefinedAnswer = predefinedAnswers[userMessage]; setMessages((prevMessages) => [ ...prevMessages, { text: `${userMessage}`, fromUser: true }, - { text: `${fixedAnswer}`, fromUser: false }, + { text: `${predefinedAnswer}`, fromUser: false }, ]); - speak({ text: fixedAnswer }); + speak({ text: predefinedAnswer }); } else { // Handle other user messages setIsTyping(true); @@ -112,6 +105,8 @@ function Chats(props) { fromUser: false, }, ]); + + setLastBotMessage(sentence); // Set the last bot message } } @@ -126,14 +121,11 @@ function Chats(props) { const lastSpokenMessageRef = useRef(null); useEffect(() => { - if (messages.length > 0) { - const lastMessage = messages[messages.length - 1]; - if (!lastMessage.fromUser && lastMessage.text !== lastSpokenMessageRef.current) { - speak({ text: lastMessage.text }); - lastSpokenMessageRef.current = lastMessage.text; - } + if (lastBotMessage && lastBotMessage !== lastSpokenMessageRef.current) { + speak({ text: lastBotMessage }); + lastSpokenMessageRef.current = lastBotMessage; } - }, [messages, speak]); + }, [lastBotMessage, speak]); const handleInputChange = (event) => { setInput(event.target.value); @@ -215,10 +207,10 @@ function Chats(props) {
- - + +
- +
{messages.map((message, index) => ( @@ -226,7 +218,7 @@ function Chats(props) { key={index} className={` flex ${message.fromUser ? 'text-black-600 justify-end' : ''} rounded-md p-1 `} > -
+

{message.fromUser ? 'You' : 'Bot'}

{message.text} @@ -234,7 +226,7 @@ function Chats(props) {

))} - + {isTyping && (
@@ -268,7 +260,7 @@ function Chats(props) { type="submit" onClick={handleSubmit} className="bg-blue-600 text-white p-2 ml-2 rounded-[50%] w-10 h-10" - > + > Ok