CopilotKit/CopilotKit
Fork: 2255 Star: 15392 (更新于 2025-01-18 12:40:01)
license: MIT
Language: TypeScript .
React UI + elegant infrastructure for AI Copilots, in-app AI agents, AI chatbots, and AI-powered Textareas 🪁
最后发布版本: v1.5.11 ( 2025-01-10 07:27:30)
Build deeply-integrated AI assistants & agents
that work alongside your users inside your applications.
Demos (click to clone / run)
|
|
An AI-powered banking interface that helps users manage transactions, analyze spending patterns, and get personalized financial advice. |
|
Interactive travel planning assistant that helps users discover destinations, create itineraries, and manage trip details with natural language. |
|
An intelligent research assistant that helps users analyze academic papers, synthesize information across multiple sources, and generate comprehensive research summaries through natural language interaction. |
Getting Started
Get started in minutes - check out the quickstart documentation.
Code Samples
// Headless UI with full control
const { visibleMessages, appendMessage, setMessages, ... } = useCopilotChat();
// Pre-built components with deep customization options (CSS + pass custom sub-components)
<CopilotPopup
instructions={"You are assisting the user as best as you can. Answer in the best way possible given the data you have."}
labels={{ title: "Popup Assistant", initial: "Need any help?" }}
/>
// ---
// Frontend RAG
useCopilotReadable({
description: "The current user's colleagues",
value: colleagues,
});
// knowledge-base integration
useCopilotKnowledgebase(myCustomKnowledgeBase)
// ---
// Frontend actions + generative UI, with full streaming support
useCopilotAction({
name: "appendToSpreadsheet",
description: "Append rows to the current spreadsheet",
parameters: [
{ name: "rows", type: "object[]", attributes: [{ name: "cells", type: "object[]", attributes: [{ name: "value", type: "string" }] }] }
],
render: ({ status, args }) => <Spreadsheet data={canonicalSpreadsheetData(args.rows)} />,
handler: ({ rows }) => setSpreadsheet({ ...spreadsheet, rows: [...spreadsheet.rows, ...canonicalSpreadsheetData(rows)] }),
});
// ---
// structured autocomplete for anything
const { suggestions } = useCopilotStructuredAutocompletion(
{
instructions: `Autocomplete or modify spreadsheet rows based on the inferred user intent.`,
value: { rows: spreadsheet.rows.map((row) => ({ cells: row })) },
enabled: !!activeCell && !spreadsheetIsEmpty,
},
[activeCell, spreadsheet]
);
Code Samples (CoAgents: in-app LangGraph Agents)
// Share state between app and agent
const { agentState } = useCoAgent({
name: "basic_agent",
initialState: { input: "NYC" }
});
// agentic generative UI
useCoAgentStateRender({
name: "basic_agent",
render: ({ state }) => <WeatherDisplay {...state.final_response} />,
});
// Human in the Loop (Approval)
useCopilotAction({
name: "email_tool",
parameters: [{ name: "email_draft", type: "string", description: "The email content", required: true }],
renderAndWaitForResponse: ({ args, status, respond }) => (
<EmailConfirmation
emailContent={args.email_draft || ""}
isExecuting={status === "executing"}
onCancel={() => respond?.({ approved: false })}
onSend={() => respond?.({ approved: true, metadata: { sentAt: new Date().toISOString() } })}
/>
),
});
// ---
// intermediate agent state streaming (supports both LangGraph.js + LangGraph python)
const modifiedConfig = copilotKitCustomizeConfig(config, {
emitIntermediateState: [{
stateKey: "outline",
tool: "set_outline",
toolArgument: "outline"
}],
});
const response = await ChatOpenAI({ model: "gpt-4o" }).invoke(messages, modifiedConfig);
Contributing
Thanks for your interest in contributing to CopilotKit! 💜
We value all contributions, whether it's through code, documentation, creating demo apps, or just spreading the word.
Here are a few useful resources to help you get started:
-
For code contributions, CONTRIBUTING.md.
-
For documentation-related contributions, check out the documentation contributions guide.
-
Want to contribute but not sure how? Join our Discord and we'll help you out!
💡 NOTE: All contributions must be submitted via a pull request and be reviewed by our team. This ensures all contributions are of high quality and align with the project's goals.
Get in touch
You are invited to join our community on Discord and chat with our team and other community members.
License
This repository's source code is available under the MIT License.
最近版本更新:(数据更新于 2025-01-18 18:29:22)
2025-01-10 07:27:30 v1.5.11
2025-01-10 07:10:55 v1.5.10
2025-01-10 07:03:29 v1.5.9
2025-01-10 07:01:03 v1.5.8
2025-01-10 04:15:17 @copilotkit/sdk-js@1.5.1-next.2
2025-01-10 04:15:14 @copilotkit/shared@1.5.1-next.2
2025-01-10 04:15:11 @copilotkit/runtime-client-gql@1.5.1-next.2
2025-01-10 04:15:08 @copilotkit/react-textarea@1.5.1-next.2
2025-01-10 04:15:05 @copilotkit/react-ui@1.5.1-next.2
2025-01-10 04:15:02 @copilotkit/runtime@1.5.1-next.2
主题(topics):
agent, agents, ai, ai-agent, ai-assistant, assistant, copilot, copilot-chat, hacktoberfest, langchain, langgraph, llm, nextjs, open-source, react, reactjs, ts, typescript
CopilotKit/CopilotKit同语言 TypeScript最近更新仓库
2025-01-18 13:15:01 labring/FastGPT
2025-01-18 06:05:49 RSSNext/Follow
2025-01-18 04:09:49 bluesky-social/social-app
2025-01-17 20:54:16 lobehub/lobe-chat
2025-01-17 11:06:01 TBXark/ChatGPT-Telegram-Workers
2025-01-16 11:13:58 siyuan-note/siyuan