Merge pull request 'main' (#3) from React-Group/interstellar_ai:main into main

Reviewed-on: https://interstellardevelopment.org/code/code/YasinOnm08/interstellar_ai/pulls/3
This commit is contained in:
YasinOnm08 2024-09-18 16:30:43 +02:00
commit e50a5259ad
5 changed files with 76 additions and 11 deletions

View file

@ -26,39 +26,44 @@ const handleCopyClick = () => {
// Handle copy action // Handle copy action
}; };
const InputBackend:React.FC = () => { const InputBackend: React.FC = () => {
async function prompt_mistral(model: string, prompt: string, system: string) { async function prompt_mistral(model: string, prompt: string, system: string) {
const apiKey = "m3kZRjN8DRSIo88r8Iti9hmKGWIklrLY"; const apiKey = "m3kZRjN8DRSIo88r8Iti9hmKGWIklrLY";
const client = new Mistral({ apiKey: apiKey }); const client = new Mistral({ apiKey: apiKey });
var chatResponse = await client.chat.complete({ var chatResponse = await client.chat.complete({
model: model, model: model,
messages: [{ role: 'user', content: prompt }, { role: 'system', content: system, }], messages: [{ role: 'user', content: prompt }, { role: 'system', content: system, }],
}); });
if (chatResponse && chatResponse.choices && chatResponse.choices.length > 0) { if (chatResponse && chatResponse.choices && chatResponse.choices.length > 0) {
if (chatResponse.choices[0].message.content) { if (chatResponse.choices[0].message.content) {
addMessage('AI: ' + chatResponse.choices[0].message.content); addMessage('AI: ' + chatResponse.choices[0].message.content);
console.error('Error: Brain Not Found');
console.log(messages) console.log(messages)
} }
} else { } else {
console.error('Error: Unexpected API response:', chatResponse); console.error('Error: Unexpected API response:', chatResponse);
} }
} }
const handleSendClick = (message: string) => { const handleSendClick = (message: string) => {
var system = "You are a helpful assistant. The following is the chat history."
for (let index = 0; index < messages.length; index++) {
system += messages[index] + " ";
};
addMessage('User: ' + message); addMessage('User: ' + message);
prompt_mistral("mistral-large-latest", message, "You are a helpful assistant.") prompt_mistral("mistral-large-latest", message, system)
}; };
const [messages, setMessages] = useState([ const [messages, setMessages] = useState([
'User: Hello!', 'User: Hello!',
'AI: Hi there!', 'AI: Hi there!',
'User: How are you?', 'User: How are you?',
'AI: Im good, thank you!' 'AI: Im good, thank you!'
]); ]);
const addMessage = (message: string) => { const addMessage = (message: string) => {
setMessages((prevMessages) => [...prevMessages, message]); setMessages((prevMessages) => [...prevMessages, message]);
}; };
@ -69,12 +74,12 @@ const InputBackend:React.FC = () => {
onResendClick={handleResendClick} onResendClick={handleResendClick}
onEditClick={handleEditClick} onEditClick={handleEditClick}
onCopyClick={handleCopyClick} onCopyClick={handleCopyClick}
/> />
<InputFrontend <InputFrontend
message="" message=""
onSendClick={handleSendClick} onSendClick={handleSendClick}
onMicClick={handleMicClick} onMicClick={handleMicClick}
/> />
</div> </div>
); );
}; };

View file

@ -10,6 +10,7 @@ header {
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
z-index: 1000; z-index: 1000;
font-family: var(--font-family); font-family: var(--font-family);
height: 5vh;
} }
header li { header li {

View file

@ -5,8 +5,9 @@
overflow: hidden; overflow: hidden;
background-color: var(--history-background-color); background-color: var(--history-background-color);
padding: 1em; padding: 1em;
border-radius: 2em;
margin: 1em; margin: 1em;
margin-right: 0;
border-radius: 2em;
} }
.history { .history {

View file

@ -11,3 +11,4 @@
@import './input.css'; @import './input.css';
@import './faq.css'; @import './faq.css';
@import './scrollbar.css'; @import './scrollbar.css';
@import './responsive.css';

57
app/styles/responsive.css Normal file
View file

@ -0,0 +1,57 @@
/* responsive.css */
/* Responsive behavior - applies only on smaller screens */
@media (max-width: 1200px) {
/* Left panel as an overlay */
.left-panel {
margin: 0 auto;
min-width: 100vw;
max-width: 100vw;
padding: 1em;
}
.left-panel.hidden {
width: 0;
/* Set width to 0 when hidden */
visibility: hidden;
/* Fully hide the panel */
margin: 0;
padding: 0;
overflow: hidden;
}
header {
height: 125px;
}
header li {
flex-direction: column;
display: block;
padding: 2px;
}
body {
margin-top: 100px;
}
.conversation-container.expanded {
width: 0;
/* Set width to 0 when hidden */
visibility: hidden;
/* Fully hide the panel */
margin: 0;
padding: 0;
overflow: hidden;
}
.conversation-container.collapsed {
margin: 0 auto;
min-width: 100vw;
max-width: 100vw;
padding: 1em;
margin-left: 0;
}
}