-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #190 from mikepsinn/develop
Text 2 measurements chat page
- Loading branch information
Showing
13 changed files
with
303 additions
and
268 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -43,4 +43,4 @@ next-env.d.ts | |
.idea/ | ||
|
||
# Docker Compose Volumes | ||
/data/ | ||
/data/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
99 changes: 99 additions & 0 deletions
99
apps/nextjs/app/dashboard/image2measurements/ChatComponent.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
import React from 'react'; | ||
import {FunctionCallHandler, nanoid} from 'ai'; | ||
import {Message, useChat} from 'ai/react'; | ||
|
||
interface ChatComponentProps { | ||
base64Image: string; | ||
} | ||
|
||
const ChatComponent: React.FC<ChatComponentProps> = ({ base64Image }) => { | ||
console.log('Base64 image:', base64Image); | ||
const functionCallHandler: FunctionCallHandler = async ( | ||
chatMessages, | ||
functionCall, | ||
) => { | ||
if (functionCall.name === 'get_custom_description') { | ||
if (functionCall.arguments) { | ||
const parsedFunctionCallArguments: { prompt: string } = JSON.parse( | ||
functionCall.arguments, | ||
); | ||
// Here you can handle the custom description logic | ||
// For example, you can send a request to your API to get the custom description | ||
// Then, you can add the custom description to the chat messages | ||
|
||
// Send a request to the GPT-4 Vision API with the base64 image and the new prompt | ||
const customDescriptionResponse = await fetch('/api/image2measurements', { | ||
method: 'POST', | ||
headers: { | ||
'Content-Type': 'application/json', | ||
}, | ||
body: JSON.stringify({ | ||
file: base64Image, | ||
prompt: parsedFunctionCallArguments.prompt, | ||
max_tokens: 100, // replace 100 with the number of tokens you want | ||
// Include any other parameters you need | ||
}), | ||
}); | ||
|
||
const responseData = await customDescriptionResponse.json(); | ||
const customDescription = responseData.analysis; | ||
|
||
return { | ||
messages: [ | ||
...chatMessages, | ||
{ | ||
id: nanoid(), | ||
name: 'get_custom_description', | ||
role: 'function' as const, | ||
content: customDescription, | ||
}, | ||
], | ||
}; | ||
} | ||
} | ||
}; | ||
|
||
const { messages, input, handleInputChange, handleSubmit } = useChat({ | ||
api: '/api/chat-with-functions', | ||
experimental_onFunctionCall: functionCallHandler, | ||
}); | ||
|
||
const roleToColorMap: { [key: string]: string } = { | ||
system: 'red', | ||
user: 'black', | ||
function: 'blue', | ||
assistant: 'green', | ||
data: 'purple', // Added color for 'data' | ||
tool: 'orange' // Added color for 'tool' | ||
}; | ||
|
||
return ( | ||
<div className="flex flex-col w-full max-w-md py-24 mx-auto stretch"> | ||
{messages.length > 0 | ||
? messages.map((m: Message) => ( | ||
<div | ||
key={m.id} | ||
className="whitespace-pre-wrap" | ||
style={{ color: roleToColorMap[m.role] || 'defaultColor' }} // Provide a default color if the role is not found | ||
> | ||
<strong>{`${m.role}: `}</strong> | ||
{m.content || JSON.stringify(m.function_call)} | ||
<br /> | ||
<br /> | ||
</div> | ||
)) | ||
: null} | ||
<div id="chart-goes-here"></div> | ||
<form onSubmit={handleSubmit}> | ||
<input | ||
className="fixed bottom-0 w-full max-w-md p-2 mb-8 border border-gray-300 rounded shadow-xl" | ||
value={input} | ||
placeholder="Ask a question about your data..." | ||
onChange={handleInputChange} | ||
/> | ||
</form> | ||
</div> | ||
); | ||
} | ||
|
||
export default ChatComponent; |
Oops, something went wrong.