examples/v1/form-filling/README.md
Transform tedious form-filling into natural conversations. Your AI assistant asks the right questions, understands context, and completes forms for you—no more field-by-field drudgery.
Click here for a running example
<div align="center"> <a href="https://copilotkit.ai" target="_blank"> </a> <a href="https://nextjs.org" target="_blank"> </a> <a href="https://ui.shadcn.com/" target="_blank"> </a> </div>Clone the repository:
git clone https://github.com/CopilotKit/CopilotKit.git
cd CopilotKit/examples/copilot-form-filling
Install dependencies:
pnpm install
# Using yarn
yarn install
# Using pnpm
npm install
Create a .env file in the project root and add your Copilot Cloud Public API Key:
NEXT_PUBLIC_COPILOT_PUBLIC_API_KEY=your_copilotkit_api_key
Start the development server:
pnpm dev
# Using yarn
yarn dev
# Using pnpm
npm run dev
Open http://localhost:3000 in your browser to see the application.
This demo uses several key CopilotKit features:
This provides the chat context to all of the children components.
<em>app/layout.tsx</em>
export default function RootLayout({
children,
}: Readonly<{ children: React.ReactNode }>) {
return (
<html lang="en">
<body
className={`${geistSans.variable} ${geistMono.variable} antialiased`}
>
<CopilotKit
publicApiKey={process.env.NEXT_PUBLIC_COPILOT_PUBLIC_API_KEY}
>
{children}
</CopilotKit>
</body>
</html>
);
}
This provides the form fields and their current values to the AI so it understands the current state of the form and session.
<em>components/IncidentReportForm.tsx</em>
useCopilotReadable({
description: "The security incident form fields and their current values",
value: formState,
});
<em>app/page.tsx</em>
useCopilotReadable({
description: "The current user information",
value: retrieveUserInfo(),
});
This allows the AI to update the form fields.
<em>components/IncidentReportForm.tsx</em>
useCopilotAction({
name: "fillIncidentReportForm",
description: "Fill out the incident report form",
parameters: [
{
name: "fullName",
type: "string",
required: true,
description: "The full name of the person reporting the incident",
},
// other parameters ...
],
handler: async (action) => {
form.setValue("name", action.fullName);
form.setValue("email", action.email);
form.setValue("description", action.incidentDescription);
form.setValue("date", new Date(action.date));
form.setValue("impactLevel", action.incidentLevel);
form.setValue("incidentType", action.incidentType);
},
});
Ready to build your own AI-powered form assistant? Check out these resources:
CopilotKit Documentation - Comprehensive guides and API references to help you build your own copilots.
CopilotKit Cloud - Deploy your copilots with our managed cloud solution for production-ready AI assistants.