From 5f017026e2975929e7c81697f8f511f751299ed1 Mon Sep 17 00:00:00 2001 From: sageTheDM Date: Fri, 11 Oct 2024 10:00:31 +0200 Subject: [PATCH] History comments --- app/components/History.tsx | 150 +++++++++++++++++++++---------------- 1 file changed, 84 insertions(+), 66 deletions(-) diff --git a/app/components/History.tsx b/app/components/History.tsx index ad8e9af..a479b70 100644 --- a/app/components/History.tsx +++ b/app/components/History.tsx @@ -1,96 +1,114 @@ import React, { useState } from 'react'; -import { useChatHistory } from '../hooks/useChatHistory'; +import { useChatHistory } from '../hooks/useChatHistory'; // Importing the custom hook for chat history const History: React.FC = () => { - const [chatHistory, setSelectedIndex, setChatHistory] = useChatHistory() - const [isEditing, setIsEditing] = useState(false); - const [inputValue, setInputValue] = useState(''); - const [hoveredIndex, setHoveredIndex] = useState(null) - + // Destructuring values from the useChatHistory hook + const [chatHistory, setSelectedIndex, setChatHistory] = useChatHistory(); + const [isEditing, setIsEditing] = useState(false); // State to manage edit mode + const [inputValue, setInputValue] = useState(''); // State for input field + const [hoveredIndex, setHoveredIndex] = useState(null); // State to track hovered chat index + // Function to activate editing mode const handleEditButtonClick = () => { setIsEditing(true); }; + // Function to update input value as the user types const handleInputChange = (e: React.ChangeEvent) => { setInputValue(e.target.value); }; + // Function to save the new chat const handleSaveButtonClick = () => { - setIsEditing(false); - chatHistory.chats.push({ name: inputValue, messages: [], timestamp: 5 }) - setInputValue("") + setIsEditing(false); // Exit edit mode + // Add a new chat entry to the history + chatHistory.chats.push({ name: inputValue, messages: [], timestamp: 5 }); + setInputValue(''); // Reset input value }; + // Function to select a chat from the history const handleHistoryClick = (index: number) => { - setSelectedIndex(index) - console.log("index",index); - } + setSelectedIndex(index); // Set the selected index to the clicked chat + console.log("index", index); + }; - const handleHistoryHover = (index:number) => { - setHoveredIndex(index) - } + // Function to handle hover over a chat entry + const handleHistoryHover = (index: number) => { + setHoveredIndex(index); // Set hovered index + }; + // Function to reset hovered index when not hovering const handleHistoryNotHover = () => { - setHoveredIndex(null) - } - - console.log("chat length",chatHistory.chats.length) - console.log("index",chatHistory.selectedIndex) + setHoveredIndex(null); // Reset hovered index + }; + // Debugging information for chat history length and selected index + console.log("chat length", chatHistory.chats.length); + console.log("index", chatHistory.selectedIndex); + + // Function to delete a chat entry const handleHistoryDeletion = (index: number) => { - const currentIndex = chatHistory.selectedIndex; + const currentIndex = chatHistory.selectedIndex; // Get the currently selected index - // Create a new copy of the current chat history + // Create a new copy of the chat history const copyChats = { ...chatHistory }; - copyChats.chats = [...chatHistory.chats] - - // Remove the chat at the specified index - copyChats.chats.splice(index,1) + copyChats.chats = [...chatHistory.chats]; - // Determine new selectedIndex - let newSelectedIndex = currentIndex; + // Remove the chat at the specified index + copyChats.chats.splice(index, 1); - // Adjust selectedIndex based on the deletion - if (index === currentIndex) { - // If the deleted index is the currently selected one, reset the selected index - newSelectedIndex = copyChats.chats.length > 0 ? (index > 0 ? index - 1 : 0) : -1; // Set to previous or first chat or -1 if no chats left - } else if (index < currentIndex) { - // If the deleted chat is before the current selected index, decrement the selected index - newSelectedIndex = currentIndex - 1; + // Determine the new selectedIndex + let newSelectedIndex = currentIndex; + + // Adjust selectedIndex based on the deletion + if (index === currentIndex) { + // If the deleted index is currently selected, reset the selected index + newSelectedIndex = copyChats.chats.length > 0 ? (index > 0 ? index - 1 : 0) : -1; // Set to previous or first chat or -1 if no chats left + } else if (index < currentIndex) { + // If the deleted chat is before the current selected index, decrement the selected index + newSelectedIndex = currentIndex - 1; } - - copyChats.selectedIndex = newSelectedIndex - - console.log(copyChats) - // Set the updated chat history - setChatHistory(copyChats); -}; - + copyChats.selectedIndex = newSelectedIndex; // Update the selected index + + // Debugging information to inspect the modified chat history + console.log(copyChats); + + // Set the updated chat history + setChatHistory(copyChats); + }; + return (
) : ( )} @@ -120,4 +138,4 @@ const History: React.FC = () => { ); } - export default History; +export default History; // Exporting the History component