mirror of
https://github.com/DayuanJiang/next-ai-draw-io.git
synced 2026-01-02 22:32:27 +08:00
feat: enhance chat functionality with XML guide integration and improved tool descriptions
This commit is contained in:
@@ -1,57 +1,67 @@
|
||||
import { google } from "@ai-sdk/google";
|
||||
import { Message } from "ai/react";
|
||||
import { streamText } from "ai";
|
||||
import { z } from "zod";
|
||||
import { readFileSync } from 'fs';
|
||||
import { resolve } from 'path';
|
||||
|
||||
// Allow streaming responses up to 30 seconds
|
||||
export const maxDuration = 30;
|
||||
|
||||
// Define tool interfaces
|
||||
interface DisplayFlowChartArgs {
|
||||
xml: string;
|
||||
}
|
||||
// Read the XML guide from file
|
||||
|
||||
interface ToolContext {
|
||||
getCurrentXML: () => string;
|
||||
displayChart: (xml: string) => void;
|
||||
}
|
||||
const guide = readFileSync(resolve('./app/api/chat/xml_guide.md'), 'utf8');
|
||||
|
||||
export async function POST(req: Request) {
|
||||
let { messages } = await req.json();
|
||||
const { messages } = await req.json();
|
||||
|
||||
|
||||
// Read and escape the guide content
|
||||
const systemMessage = `
|
||||
You are a helpful assistant that can create, edit, and display flowcharts using draw.io.
|
||||
You can use the following tools:
|
||||
- display_flow_chart: Display a flowchart on draw.io.
|
||||
- fetch_flow_chart: Get the current flowchart XML from draw.io.
|
||||
You can use the tools to create and manipulate flowcharts.
|
||||
You can also answer questions and provide explanations.
|
||||
You are a helpful assistant that can create, edit, and display flowcharts using draw.io through xml strings.
|
||||
You can use the following tools:
|
||||
---Tool1---
|
||||
tool name: display_flow_chart
|
||||
description: write a xml and display it on draw.io
|
||||
parameters: {
|
||||
xml: string
|
||||
}
|
||||
---Tool2---
|
||||
tool name: fetch_flow_chart
|
||||
description: Get the current flowchart XML from draw.io
|
||||
parameters: {}
|
||||
---End of tools---
|
||||
|
||||
When you need to modify the flowchart, you need fetch the current flowchart XML from draw.io and then modify it and display it again.
|
||||
here is a guide for the XML format: ${guide}
|
||||
You can use the tools to create and manipulate flowcharts.
|
||||
You can also answer questions and provide explanations.
|
||||
If user want you to draw something rather than flowchart, you can use the combination of the shape to draw it.
|
||||
`;
|
||||
if (messages.length === 1) {
|
||||
messages = [
|
||||
{
|
||||
"role": "system",
|
||||
"content": systemMessage,
|
||||
},
|
||||
...messages,
|
||||
];
|
||||
}
|
||||
const response = streamText({
|
||||
|
||||
// Add system message if only user message is provided
|
||||
const enhancedMessages = messages.length === 1
|
||||
? [{ role: "system", content: systemMessage }, ...messages]
|
||||
: messages;
|
||||
|
||||
const result = streamText({
|
||||
model: google("gemini-2.0-flash"),
|
||||
messages,
|
||||
messages: enhancedMessages,
|
||||
tools: {
|
||||
// Client-side tool that will be executed on the client
|
||||
display_flow_chart: {
|
||||
description: "Display a flowchart on draw.io",
|
||||
parameters: z.object(
|
||||
{
|
||||
xml: z.string().describe("XML string to be displayed on draw.io"),
|
||||
},
|
||||
)
|
||||
parameters: z.object({
|
||||
xml: z.string().describe("XML string to be displayed on draw.io")
|
||||
})
|
||||
},
|
||||
// Client-side tool that will be executed on the client
|
||||
fetch_flow_chart: {
|
||||
description: "Get the current flowchart XML from draw.io",
|
||||
parameters: z.object({}),
|
||||
parameters: z.object({})
|
||||
}
|
||||
},
|
||||
temperature: 0,
|
||||
});
|
||||
|
||||
return response.toDataStreamResponse();
|
||||
return result.toDataStreamResponse();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user