create-ag-ui-app 0.0.35 ā 0.0.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -11
- package/dist/index.js +12 -18
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +15 -21
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -2,21 +2,23 @@
|
|
|
2
2
|
|
|
3
3
|
CLI tool for scaffolding **Agent-User Interaction (AG-UI) Protocol** applications.
|
|
4
4
|
|
|
5
|
-
`create-ag-ui-app` provides an interactive setup wizard to quickly bootstrap AG-UI projects with your preferred client framework and agent backend.
|
|
5
|
+
`create-ag-ui-app` provides an interactive setup wizard to quickly bootstrap AG-UI projects with your preferred client framework and agent backend.
|
|
6
6
|
|
|
7
|
-
|
|
7
|
+
Choose from CopilotKit/Next.js for web apps or CLI clients for terminal-based interactions.
|
|
8
|
+
|
|
9
|
+
## Usage
|
|
8
10
|
|
|
9
11
|
```bash
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
12
|
+
npx create-ag-ui-app@latest
|
|
13
|
+
pnpx create-ag-ui-app@latest
|
|
14
|
+
bunx create-ag-ui-app@latest
|
|
13
15
|
```
|
|
14
16
|
|
|
15
17
|
## Features
|
|
16
18
|
|
|
17
19
|
- šÆ **Interactive setup** ā Guided prompts for client and framework selection
|
|
18
20
|
- š **Multiple clients** ā CopilotKit/Next.js web apps and CLI clients
|
|
19
|
-
- š§ **Framework integration** ā Built-in support for LangGraph, CrewAI, Mastra,
|
|
21
|
+
- š§ **Framework integration** ā Built-in support for LangGraph, CrewAI, Mastra, Agno, LlamaIndex, and more
|
|
20
22
|
- š¦ **Zero config** ā Automatically sets up dependencies and project structure
|
|
21
23
|
- ā” **Quick start** ā Get from idea to running app in minutes
|
|
22
24
|
|
|
@@ -24,21 +26,24 @@ yarn create ag-ui-app
|
|
|
24
26
|
|
|
25
27
|
```bash
|
|
26
28
|
# Interactive setup
|
|
27
|
-
|
|
29
|
+
npx create-ag-ui-app@latest
|
|
28
30
|
|
|
29
31
|
# With framework flags
|
|
30
|
-
|
|
31
|
-
|
|
32
|
+
npx create-ag-ui-app@latest --langgraph-py
|
|
33
|
+
npx create-ag-ui-app@latest --mastra
|
|
34
|
+
|
|
35
|
+
# See all options
|
|
36
|
+
npx create-ag-ui-app@latest --help
|
|
32
37
|
```
|
|
33
38
|
|
|
34
39
|
## Documentation
|
|
35
40
|
|
|
36
41
|
- Concepts & architecture: [`docs/concepts`](https://docs.ag-ui.com/concepts/architecture)
|
|
37
|
-
- Full API reference: [`docs/
|
|
42
|
+
- Full API reference: [`docs/events`](https://docs.ag-ui.com/concepts/events)
|
|
38
43
|
|
|
39
44
|
## Contributing
|
|
40
45
|
|
|
41
|
-
Bug reports and pull requests are welcome! Please read our [contributing guide](https://
|
|
46
|
+
Bug reports and pull requests are welcome! Please read our [contributing guide](https://github.com/ag-ui-protocol/ag-ui/blob/main/CONTRIBUTING.md) first.
|
|
42
47
|
|
|
43
48
|
## License
|
|
44
49
|
|
package/dist/index.js
CHANGED
|
@@ -1,30 +1,24 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var
|
|
3
|
-
${
|
|
2
|
+
"use strict";var w=Object.create;var g=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,P=Object.prototype.hasOwnProperty;var $=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of k(e))!P.call(o,a)&&a!==t&&g(o,a,{get:()=>e[a],enumerable:!(n=y(e,a))||n.enumerable});return o};var l=(o,e,t)=>(t=o!=null?w(j(o)):{},$(e||!o||!o.__esModule?g(t,"default",{value:o,enumerable:!0}):t,o));var d=require("commander"),i=l(require("inquirer")),f=require("child_process"),c=l(require("fs")),u=l(require("path")),h=require("giget"),r=new d.Command,b="\x1B[35m",I="\x1B[0m";function A(){let o=`
|
|
3
|
+
${b} \u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
|
|
4
4
|
\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
5
5
|
\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
6
6
|
\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2550\u2550\u2550\u2550\u255D\u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
7
7
|
\u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2551
|
|
8
8
|
\u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D
|
|
9
|
-
${
|
|
9
|
+
${I}
|
|
10
10
|
Agent User Interactivity Protocol
|
|
11
|
-
`;console.log(o)}
|
|
11
|
+
`;console.log(o)}var C=`
|
|
12
|
+
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
13
|
+
`;async function x(){A(),console.log(`
|
|
12
14
|
~ Let's get started building an AG-UI powered user interactive agent ~`),console.log(` Read more about AG-UI at https://ag-ui.com
|
|
13
|
-
`),console.log(""),console.log("To build an AG-UI app, you need to select a client."),console.log("");
|
|
14
|
-
|
|
15
|
-
`),
|
|
16
|
-
`)
|
|
17
|
-
|
|
18
|
-
\u2705 Next.js app created successfully!`),r()):(console.log(`
|
|
19
|
-
\u274C Failed to create Next.js app`),j(new Error(`create-next-app exited with code ${w}`)))})});try{process.chdir(n)}catch(r){console.log("\u274C Error changing directory:",r),process.exit(1)}}console.log(`
|
|
20
|
-
\u{1F680} Running CopilotKit initialization...
|
|
21
|
-
`);let a=p.opts(),s=[];a.langgraph?s.push("-m","LangGraph"):a.crewiAiCrews?s.push("-m","CrewAI","--crew-type","Crews"):a.crewiAiFlows?s.push("-m","CrewAI","--crew-type","Flows"):a.mastra?s.push("-m","Mastra"):a.ag2?s.push("-m","AG2"):a.llamaindex?s.push("-m","LlamaIndex"):a.agno&&s.push("-m","Agno"),(0,u.spawn)("npx",["copilotkit","init",...s],{stdio:"inherit",shell:!0}).on("close",i=>{i!==0&&console.log(`
|
|
22
|
-
\u274C Project creation failed.`)})}async function E(){console.log(`\u{1F527} Setting up CLI client...
|
|
23
|
-
`),console.log("\u{1F50D} Reading current package versions...");let o=await S();console.log(`\u{1F4CB} Found versions: ${Object.keys(o).length} packages`),Object.entries(o).forEach(([t,n])=>{console.log(` - ${t}: ${n}`)}),console.log("");let e=await c.default.prompt([{type:"input",name:"name",message:"What would you like to name your CLI project?",default:"my-ag-ui-cli-app",validate:t=>t.trim()?/^[a-zA-Z0-9-_]+$/.test(t)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);try{console.log(`\u{1F4E5} Downloading CLI client template: ${e.name}
|
|
24
|
-
`),await(0,y.downloadTemplate)("gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example",{dir:e.name,install:!1}),console.log("\u2705 CLI client template downloaded successfully!"),console.log(`
|
|
25
|
-
\u{1F504} Updating workspace dependencies...`),await v(e.name,o),console.log(`
|
|
15
|
+
`);let o=r.opts();if(["langgraphPy","langgraphJs","crewaiFlows","mastra","ag2","llamaindex","pydanticAi","agno"].some(n=>o[n])){await m();return}else console.log(""),console.log("To build an AG-UI app, you need to select a client."),console.log("");switch((await i.default.prompt([{type:"list",name:"client",message:"What client do you want to use?",choices:["CopilotKit/Next.js","CLI client",new i.default.Separator(" Other clients coming soon (SMS, Whatsapp, Slack ...)")]}])).client){case"CopilotKit/Next.js":await m();break;case"CLI client":await U();break;default:break}}async function m(){let o=r.opts(),e=[],t=await i.default.prompt([{type:"input",name:"name",message:"What would you like to name your project?",default:"my-ag-ui-app",validate:a=>a.trim()?/^[a-zA-Z0-9-_]+$/.test(a)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);o.langgraphPy?e.push("-f","langgraph-py"):o.langgraphJs?e.push("-f","langgraph-js"):o.crewiAiFlows?e.push("-f","flows"):o.mastra?e.push("-f","mastra"):o.ag2?e.push("-f","ag2"):o.llamaindex?e.push("-f","llamaindex"):o.agno?e.push("-f","agno"):o.pydanticAi&&e.push("-f","pydantic-ai"),(0,f.spawn)("npx",["copilotkit@latest","create","--no-banner","-n",t.name,...e],{stdio:"inherit",shell:!0}).on("close",a=>{a!==0&&console.log(`
|
|
16
|
+
\u274C Project creation failed.`)})}async function U(){console.log(`\u{1F527} Setting up CLI client...
|
|
17
|
+
`),console.log("\u{1F50D} Reading current package versions...");let o=await v();console.log(`\u{1F4CB} Found versions: ${Object.keys(o).length} packages`),Object.entries(o).forEach(([t,n])=>{console.log(` - ${t}: ${n}`)}),console.log("");let e=await i.default.prompt([{type:"input",name:"name",message:"What would you like to name your CLI project?",default:"my-ag-ui-cli-app",validate:t=>t.trim()?/^[a-zA-Z0-9-_]+$/.test(t)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);try{console.log(`\u{1F4E5} Downloading CLI client template: ${e.name}
|
|
18
|
+
`),await(0,h.downloadTemplate)("gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example",{dir:e.name,install:!1}),console.log("\u2705 CLI client template downloaded successfully!"),console.log(`
|
|
19
|
+
\u{1F504} Updating workspace dependencies...`),await L(e.name,o),console.log(`
|
|
26
20
|
\u{1F4C1} Project created in: ${e.name}`),console.log(`
|
|
27
21
|
\u{1F680} Next steps:`),console.log(" export OPENAI_API_KEY='your-openai-api-key'"),console.log(` cd ${e.name}`),console.log(" npm install"),console.log(" npm run dev"),console.log(`
|
|
28
|
-
\u{1F4A1} Check the README.md for more information on how to use your CLI client!`)}catch(t){console.log("\u274C Failed to download CLI client template:",t),process.exit(1)}}
|
|
22
|
+
\u{1F4A1} Check the README.md for more information on how to use your CLI client!`)}catch(t){console.log("\u274C Failed to download CLI client template:",t),process.exit(1)}}r.name("create-ag-ui-app").description(C).version("0.0.36");r.option("--langgraph-py","Use the LangGraph framework with Python").option("--langgraph-js","Use the LangGraph framework with JavaScript").option("--crewai-flows","Use the CrewAI framework with Flows").option("--mastra","Use the Mastra framework").option("--pydantic-ai","Use the Pydantic AI framework").option("--llamaindex","Use the LlamaIndex framework").option("--agno","Use the Agno framework").option("--ag2","Use the AG2 framework");r.action(async()=>{await x()});r.parse();async function v(){var t;let o=["@ag-ui/client","@ag-ui/core","@ag-ui/mastra"],e={};for(let n of o)try{let a=await fetch(`https://registry.npmjs.org/${n}`);if(a.ok){let s=await a.json();e[n]=((t=s["dist-tags"])==null?void 0:t.latest)||"latest",console.log(` \u2713 ${n}: ${e[n]}`)}else console.log(` \u26A0\uFE0F Could not fetch version for ${n}`),e[n]="latest"}catch(a){console.log(` \u26A0\uFE0F Error fetching ${n}: ${a}`),e[n]="latest"}return e}async function L(o,e){let t=u.default.join(o,"package.json");try{if(!c.default.existsSync(t)){console.log("\u26A0\uFE0F No package.json found in downloaded project");return}let n=JSON.parse(c.default.readFileSync(t,"utf-8")),a=!1;if(n.dependencies)for(let[s,p]of Object.entries(n.dependencies))typeof p=="string"&&p.startsWith("workspace:")&&e[s]&&(n.dependencies[s]=`^${e[s]}`,a=!0,console.log(` \u{1F4E6} Updated ${s}: workspace:* \u2192 ^${e[s]}`));a?(c.default.writeFileSync(t,JSON.stringify(n,null,2)+`
|
|
29
23
|
`),console.log("\u2705 Package.json updated with actual package versions!")):console.log("\u{1F4C4} No workspace dependencies found to update")}catch(n){console.log(`\u274C Error updating package.json: ${n}`)}}
|
|
30
24
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport inquirer from \"inquirer\";\nimport { spawn } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { downloadTemplate } from \"giget\";\n\nconst program = new Command();\n\n// Dark purple color\nconst PURPLE = \"\\x1b[35m\";\nconst RESET = \"\\x1b[0m\";\n\nfunction displayBanner() {\n const banner = `\n${PURPLE} āāāāāā āāāāāāā āāā āāā āāā\n āāāāāāāāāāāāāāāā āāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāā āāā āāā\n āāā āāāāāāāāāāāā āāāāāāāāā āāā\n āāā āāā āāāāāāā āāāāāāā āāā\n${RESET}\n Agent User Interactivity Protocol\n`;\n console.log(banner);\n}\n\nasync function createProject() {\n displayBanner();\n\n console.log(\"\\n~ Let's get started building an AG-UI powered user interactive agent ~\");\n console.log(\" Read more about AG-UI at https://ag-ui.com\\n\");\n console.log(\"\");\n console.log(\"To build an AG-UI app, you need to select a client.\");\n console.log(\"\");\n\n const answers = await inquirer.prompt([\n {\n type: \"list\",\n name: \"client\",\n message: \"What client do you want to use?\",\n choices: [\n \"CopilotKit/Next.js\",\n \"CLI client\",\n new inquirer.Separator(\"Other clients coming soon (SMS, Whatsapp, Slack ...)\"),\n ],\n },\n ]);\n\n console.log(`\\nSelected client: ${answers.client}`);\n console.log(\"Initializing your project...\\n\");\n\n // Handle CLI client option\n if (answers.client === \"CLI client\") {\n await handleCliClient();\n return;\n }\n\n // Continue with existing CopilotKit/Next.js logic\n const packageJsonPath = path.join(process.cwd(), \"package.json\");\n const packageJsonExists = fs.existsSync(packageJsonPath);\n\n let projectDir = process.cwd();\n\n if (!packageJsonExists) {\n console.log(\"š¦ No package.json found, creating a new Next.js app...\\n\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your project?\",\n default: \"my-ag-ui-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n projectDir = path.join(process.cwd(), projectName.name);\n\n console.log(`Creating Next.js app: ${projectName.name}\\n`);\n\n const createNextApp = spawn(\n \"npx\",\n [\n \"create-next-app@latest\",\n projectName.name,\n \"--typescript\",\n \"--tailwind\",\n \"--eslint\",\n \"--app\",\n \"--src-dir\",\n \"--import-alias\",\n \"@/*\",\n \"--no-turbopack\",\n ],\n {\n stdio: \"inherit\",\n shell: true,\n },\n );\n\n await new Promise<void>((resolve, reject) => {\n createNextApp.on(\"close\", (code) => {\n if (code === 0) {\n console.log(\"\\nā
Next.js app created successfully!\");\n resolve();\n } else {\n console.log(\"\\nā Failed to create Next.js app\");\n reject(new Error(`create-next-app exited with code ${code}`));\n }\n });\n });\n\n // Change to the new project directory\n try {\n process.chdir(projectDir);\n } catch (error) {\n console.log(\"ā Error changing directory:\", error);\n process.exit(1);\n }\n }\n\n // Run copilotkit init with framework flags\n console.log(\"\\nš Running CopilotKit initialization...\\n\");\n\n const options = program.opts();\n const frameworkArgs = [];\n\n if (options.langgraph) {\n frameworkArgs.push(\"-m\", \"LangGraph\");\n } else if (options.crewiAiCrews) {\n frameworkArgs.push(\"-m\", \"CrewAI\", \"--crew-type\", \"Crews\");\n } else if (options.crewiAiFlows) {\n frameworkArgs.push(\"-m\", \"CrewAI\", \"--crew-type\", \"Flows\");\n } else if (options.mastra) {\n frameworkArgs.push(\"-m\", \"Mastra\");\n } else if (options.ag2) {\n frameworkArgs.push(\"-m\", \"AG2\");\n } else if (options.llamaindex) {\n frameworkArgs.push(\"-m\", \"LlamaIndex\");\n } else if (options.agno) {\n frameworkArgs.push(\"-m\", \"Agno\");\n }\n\n const copilotkit = spawn(\"npx\", [\"copilotkit\", \"init\", ...frameworkArgs], {\n stdio: \"inherit\",\n shell: true,\n });\n\n copilotkit.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(\"\\nā Project creation failed.\");\n }\n });\n}\n\nasync function handleCliClient() {\n console.log(\"š§ Setting up CLI client...\\n\");\n\n // Get current package versions from the monorepo\n console.log(\"š Reading current package versions...\");\n const versions = await getCurrentPackageVersions();\n console.log(`š Found versions: ${Object.keys(versions).length} packages`);\n Object.entries(versions).forEach(([name, version]) => {\n console.log(` - ${name}: ${version}`);\n });\n console.log(\"\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your CLI project?\",\n default: \"my-ag-ui-cli-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n try {\n console.log(`š„ Downloading CLI client template: ${projectName.name}\\n`);\n\n await downloadTemplate(\"gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example\", {\n dir: projectName.name,\n install: false,\n });\n\n console.log(\"ā
CLI client template downloaded successfully!\");\n\n // Update workspace dependencies with actual versions\n console.log(\"\\nš Updating workspace dependencies...\");\n await updateWorkspaceDependencies(projectName.name, versions);\n\n console.log(`\\nš Project created in: ${projectName.name}`);\n console.log(\"\\nš Next steps:\");\n console.log(\" export OPENAI_API_KEY='your-openai-api-key'\");\n console.log(` cd ${projectName.name}`);\n console.log(\" npm install\");\n console.log(\" npm run dev\");\n console.log(\"\\nš” Check the README.md for more information on how to use your CLI client!\");\n } catch (error) {\n console.log(\"ā Failed to download CLI client template:\", error);\n process.exit(1);\n }\n}\n\nprogram.name(\"create-ag-ui-app\").description(\"AG-UI CLI\").version(\"0.0.1-alpha.1\");\n\n// Add framework flags\nprogram\n .option(\"--langgraph\", \"Use the LangGraph framework\")\n .option(\"--crewi-ai-crews\", \"Use the CrewAI framework with Crews\")\n .option(\"--crewi-ai-flows\", \"Use the CrewAI framework with Flows\")\n .option(\"--mastra\", \"Use the Mastra framework\")\n .option(\"--ag2\", \"Use the AG2 framework\")\n .option(\"--llamaindex\", \"Use the LlamaIndex framework\")\n .option(\"--agno\", \"Use the Agno framework\");\n\nprogram.action(async () => {\n await createProject();\n});\n\nprogram.parse();\n\n// Utility functions\n\n// Helper function to get package versions from npmjs\nasync function getCurrentPackageVersions(): Promise<{ [key: string]: string }> {\n const packages = [\"@ag-ui/client\", \"@ag-ui/core\", \"@ag-ui/mastra\"];\n const versions: { [key: string]: string } = {};\n\n for (const packageName of packages) {\n try {\n // Fetch package info from npm registry\n const response = await fetch(`https://registry.npmjs.org/${packageName}`);\n if (response.ok) {\n const packageInfo = await response.json();\n versions[packageName] = packageInfo[\"dist-tags\"]?.latest || \"latest\";\n console.log(` ā ${packageName}: ${versions[packageName]}`);\n } else {\n console.log(` ā ļø Could not fetch version for ${packageName}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n } catch (error) {\n console.log(` ā ļø Error fetching ${packageName}: ${error}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n }\n\n return versions;\n}\n\n// Function to update workspace dependencies in downloaded project\nasync function updateWorkspaceDependencies(\n projectPath: string,\n versions: { [key: string]: string },\n) {\n const packageJsonPath = path.join(projectPath, \"package.json\");\n\n try {\n if (!fs.existsSync(packageJsonPath)) {\n console.log(\"ā ļø No package.json found in downloaded project\");\n return;\n }\n\n const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n let updated = false;\n\n // Update workspace dependencies with actual versions\n if (packageJson.dependencies) {\n for (const [depName, depVersion] of Object.entries(packageJson.dependencies)) {\n if (\n typeof depVersion === \"string\" &&\n depVersion.startsWith(\"workspace:\") &&\n versions[depName]\n ) {\n packageJson.dependencies[depName] = `^${versions[depName]}`;\n updated = true;\n console.log(` š¦ Updated ${depName}: workspace:* ā ^${versions[depName]}`);\n }\n }\n }\n\n if (updated) {\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n console.log(\"ā
Package.json updated with actual package versions!\");\n } else {\n console.log(\"š No workspace dependencies found to update\");\n }\n } catch (error) {\n console.log(`ā Error updating package.json: ${error}`);\n }\n}\n"],"mappings":"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","names":["import_commander","import_inquirer","import_child_process","import_fs","import_path","import_giget","program","PURPLE","RESET","displayBanner","banner","createProject","answers","inquirer","handleCliClient","packageJsonPath","path","packageJsonExists","fs","projectDir","projectName","input","createNextApp","resolve","reject","code","error","options","frameworkArgs","versions","getCurrentPackageVersions","name","version","updateWorkspaceDependencies","_a","packages","packageName","response","packageInfo","projectPath","packageJson","updated","depName","depVersion"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport inquirer from \"inquirer\";\nimport { spawn } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { downloadTemplate } from \"giget\";\n\nconst program = new Command();\n\n// Dark purple color\nconst PURPLE = \"\\x1b[35m\";\nconst RESET = \"\\x1b[0m\";\n\nfunction displayBanner() {\n const banner = `\n${PURPLE} āāāāāā āāāāāāā āāā āāā āāā\n āāāāāāāāāāāāāāāā āāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāā āāā āāā\n āāā āāāāāāāāāāāā āāāāāāāāā āāā\n āāā āāā āāāāāāā āāāāāāā āāā\n${RESET}\n Agent User Interactivity Protocol\n`;\n console.log(banner);\n}\n\nconst description = `\nQuickly scaffold AG-UI enabled applications for your favorite agent frameworks.\n`\n\nasync function createProject() {\n displayBanner();\n\n console.log(\"\\n~ Let's get started building an AG-UI powered user interactive agent ~\");\n console.log(\" Read more about AG-UI at https://ag-ui.com\\n\");\n\n const options = program.opts();\n const isFrameworkDefined = [\n \"langgraphPy\",\n \"langgraphJs\",\n \"crewaiFlows\",\n \"mastra\",\n \"ag2\",\n \"llamaindex\",\n \"pydanticAi\",\n \"agno\"\n ].some(flag => options[flag]);\n\n if (isFrameworkDefined) {\n await handleCopilotKitNextJs();\n return;\n } else {\n console.log(\"\");\n console.log(\"To build an AG-UI app, you need to select a client.\");\n console.log(\"\");\n }\n\n const answers = await inquirer.prompt([\n {\n type: \"list\",\n name: \"client\",\n message: \"What client do you want to use?\",\n choices: [\n \"CopilotKit/Next.js\",\n \"CLI client\",\n new inquirer.Separator(\" Other clients coming soon (SMS, Whatsapp, Slack ...)\"),\n ],\n },\n ]);\n\n switch (answers.client) {\n case \"CopilotKit/Next.js\":\n await handleCopilotKitNextJs();\n break;\n case \"CLI client\":\n await handleCliClient();\n break;\n default:\n break;\n }\n}\n\nasync function handleCopilotKitNextJs() {\n const options = program.opts();\n const frameworkArgs: string[] = [];\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your project?\",\n default: \"my-ag-ui-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n // Translate options to CopilotKit framework flags\n if (options.langgraphPy) {\n frameworkArgs.push(\"-f\", \"langgraph-py\");\n } else if (options.langgraphJs) {\n frameworkArgs.push(\"-f\", \"langgraph-js\");\n } else if (options.crewiAiFlows) {\n frameworkArgs.push(\"-f\", \"flows\");\n } else if (options.mastra) {\n frameworkArgs.push(\"-f\", \"mastra\");\n } else if (options.ag2) {\n frameworkArgs.push(\"-f\", \"ag2\");\n } else if (options.llamaindex) {\n frameworkArgs.push(\"-f\", \"llamaindex\");\n } else if (options.agno) {\n frameworkArgs.push(\"-f\", \"agno\");\n } else if (options.pydanticAi) {\n frameworkArgs.push(\"-f\", \"pydantic-ai\");\n }\n\n const copilotkit = spawn(\"npx\", \n [\n \"copilotkit@latest\",\n \"create\",\n \"--no-banner\",\n \"-n\", projectName.name,\n ...frameworkArgs,\n ],\n {\n stdio: \"inherit\",\n shell: true,\n },\n );\n\n copilotkit.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(\"\\nā Project creation failed.\");\n }\n });\n}\n\nasync function handleCliClient() {\n console.log(\"š§ Setting up CLI client...\\n\");\n\n // Get current package versions from the monorepo\n console.log(\"š Reading current package versions...\");\n const versions = await getCurrentPackageVersions();\n console.log(`š Found versions: ${Object.keys(versions).length} packages`);\n Object.entries(versions).forEach(([name, version]) => {\n console.log(` - ${name}: ${version}`);\n });\n console.log(\"\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your CLI project?\",\n default: \"my-ag-ui-cli-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n try {\n console.log(`š„ Downloading CLI client template: ${projectName.name}\\n`);\n\n await downloadTemplate(\"gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example\", {\n dir: projectName.name,\n install: false,\n });\n\n console.log(\"ā
CLI client template downloaded successfully!\");\n\n // Update workspace dependencies with actual versions\n console.log(\"\\nš Updating workspace dependencies...\");\n await updateWorkspaceDependencies(projectName.name, versions);\n\n console.log(`\\nš Project created in: ${projectName.name}`);\n console.log(\"\\nš Next steps:\");\n console.log(\" export OPENAI_API_KEY='your-openai-api-key'\");\n console.log(` cd ${projectName.name}`);\n console.log(\" npm install\");\n console.log(\" npm run dev\");\n console.log(\"\\nš” Check the README.md for more information on how to use your CLI client!\");\n } catch (error) {\n console.log(\"ā Failed to download CLI client template:\", error);\n process.exit(1);\n }\n}\n\n// Metadata\nprogram\n .name(\"create-ag-ui-app\")\n .description(description)\n .version(\"0.0.36\");\n\n// Add framework flags\nprogram\n .option(\"--langgraph-py\", \"Use the LangGraph framework with Python\")\n .option(\"--langgraph-js\", \"Use the LangGraph framework with JavaScript\")\n .option(\"--crewai-flows\", \"Use the CrewAI framework with Flows\")\n .option(\"--mastra\", \"Use the Mastra framework\")\n .option(\"--pydantic-ai\", \"Use the Pydantic AI framework\")\n .option(\"--llamaindex\", \"Use the LlamaIndex framework\")\n .option(\"--agno\", \"Use the Agno framework\")\n .option(\"--ag2\", \"Use the AG2 framework\")\n\nprogram.action(async () => {\n await createProject();\n});\n\nprogram.parse();\n\n// Utility functions\n\n// Helper function to get package versions from npmjs\nasync function getCurrentPackageVersions(): Promise<{ [key: string]: string }> {\n const packages = [\"@ag-ui/client\", \"@ag-ui/core\", \"@ag-ui/mastra\"];\n const versions: { [key: string]: string } = {};\n\n for (const packageName of packages) {\n try {\n // Fetch package info from npm registry\n const response = await fetch(`https://registry.npmjs.org/${packageName}`);\n if (response.ok) {\n const packageInfo = await response.json();\n versions[packageName] = packageInfo[\"dist-tags\"]?.latest || \"latest\";\n console.log(` ā ${packageName}: ${versions[packageName]}`);\n } else {\n console.log(` ā ļø Could not fetch version for ${packageName}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n } catch (error) {\n console.log(` ā ļø Error fetching ${packageName}: ${error}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n }\n\n return versions;\n}\n\n// Function to update workspace dependencies in downloaded project\nasync function updateWorkspaceDependencies(\n projectPath: string,\n versions: { [key: string]: string },\n) {\n const packageJsonPath = path.join(projectPath, \"package.json\");\n\n try {\n if (!fs.existsSync(packageJsonPath)) {\n console.log(\"ā ļø No package.json found in downloaded project\");\n return;\n }\n\n const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n let updated = false;\n\n // Update workspace dependencies with actual versions\n if (packageJson.dependencies) {\n for (const [depName, depVersion] of Object.entries(packageJson.dependencies)) {\n if (\n typeof depVersion === \"string\" &&\n depVersion.startsWith(\"workspace:\") &&\n versions[depName]\n ) {\n packageJson.dependencies[depName] = `^${versions[depName]}`;\n updated = true;\n console.log(` š¦ Updated ${depName}: workspace:* ā ^${versions[depName]}`);\n }\n }\n }\n\n if (updated) {\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n console.log(\"ā
Package.json updated with actual package versions!\");\n } else {\n console.log(\"š No workspace dependencies found to update\");\n }\n } catch (error) {\n console.log(`ā Error updating package.json: ${error}`);\n }\n}\n"],"mappings":"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","names":["import_commander","import_inquirer","import_child_process","import_fs","import_path","import_giget","program","PURPLE","RESET","displayBanner","banner","description","createProject","options","flag","handleCopilotKitNextJs","inquirer","handleCliClient","frameworkArgs","projectName","input","code","versions","getCurrentPackageVersions","name","version","updateWorkspaceDependencies","error","_a","packages","packageName","response","packageInfo","projectPath","packageJsonPath","path","fs","packageJson","updated","depName","depVersion"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,30 +1,24 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{Command as
|
|
3
|
-
${
|
|
2
|
+
import{Command as g}from"commander";import i from"inquirer";import{spawn as m}from"child_process";import c from"fs";import d from"path";import{downloadTemplate as f}from"giget";var r=new g,u="\x1B[35m",h="\x1B[0m";function w(){let o=`
|
|
3
|
+
${u} \u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
|
|
4
4
|
\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
5
5
|
\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
6
6
|
\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2550\u2550\u2550\u2550\u255D\u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551
|
|
7
7
|
\u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2551
|
|
8
8
|
\u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D
|
|
9
|
-
${
|
|
9
|
+
${h}
|
|
10
10
|
Agent User Interactivity Protocol
|
|
11
|
-
`;console.log(
|
|
11
|
+
`;console.log(o)}var y=`
|
|
12
|
+
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
13
|
+
`;async function k(){w(),console.log(`
|
|
12
14
|
~ Let's get started building an AG-UI powered user interactive agent ~`),console.log(` Read more about AG-UI at https://ag-ui.com
|
|
13
|
-
`),console.log(""),console.log("To build an AG-UI app, you need to select a client."),console.log("");
|
|
14
|
-
|
|
15
|
-
`),
|
|
16
|
-
`)
|
|
17
|
-
|
|
18
|
-
\
|
|
19
|
-
\
|
|
20
|
-
\u{
|
|
21
|
-
`)
|
|
22
|
-
\u274C Project creation failed.`)})}async function I(){console.log(`\u{1F527} Setting up CLI client...
|
|
23
|
-
`),console.log("\u{1F50D} Reading current package versions...");let s=await $();console.log(`\u{1F4CB} Found versions: ${Object.keys(s).length} packages`),Object.entries(s).forEach(([t,e])=>{console.log(` - ${t}: ${e}`)}),console.log("");let o=await l.prompt([{type:"input",name:"name",message:"What would you like to name your CLI project?",default:"my-ag-ui-cli-app",validate:t=>t.trim()?/^[a-zA-Z0-9-_]+$/.test(t)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);try{console.log(`\u{1F4E5} Downloading CLI client template: ${o.name}
|
|
24
|
-
`),await y("gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example",{dir:o.name,install:!1}),console.log("\u2705 CLI client template downloaded successfully!"),console.log(`
|
|
25
|
-
\u{1F504} Updating workspace dependencies...`),await A(o.name,s),console.log(`
|
|
26
|
-
\u{1F4C1} Project created in: ${o.name}`),console.log(`
|
|
27
|
-
\u{1F680} Next steps:`),console.log(" export OPENAI_API_KEY='your-openai-api-key'"),console.log(` cd ${o.name}`),console.log(" npm install"),console.log(" npm run dev"),console.log(`
|
|
28
|
-
\u{1F4A1} Check the README.md for more information on how to use your CLI client!`)}catch(t){console.log("\u274C Failed to download CLI client template:",t),process.exit(1)}}c.name("create-ag-ui-app").description("AG-UI CLI").version("0.0.1-alpha.1");c.option("--langgraph","Use the LangGraph framework").option("--crewi-ai-crews","Use the CrewAI framework with Crews").option("--crewi-ai-flows","Use the CrewAI framework with Flows").option("--mastra","Use the Mastra framework").option("--ag2","Use the AG2 framework").option("--llamaindex","Use the LlamaIndex framework").option("--agno","Use the Agno framework");c.action(async()=>{await C()});c.parse();async function $(){var t;let s=["@ag-ui/client","@ag-ui/core","@ag-ui/mastra"],o={};for(let e of s)try{let a=await fetch(`https://registry.npmjs.org/${e}`);if(a.ok){let n=await a.json();o[e]=((t=n["dist-tags"])==null?void 0:t.latest)||"latest",console.log(` \u2713 ${e}: ${o[e]}`)}else console.log(` \u26A0\uFE0F Could not fetch version for ${e}`),o[e]="latest"}catch(a){console.log(` \u26A0\uFE0F Error fetching ${e}: ${a}`),o[e]="latest"}return o}async function A(s,o){let t=m.join(s,"package.json");try{if(!p.existsSync(t)){console.log("\u26A0\uFE0F No package.json found in downloaded project");return}let e=JSON.parse(p.readFileSync(t,"utf-8")),a=!1;if(e.dependencies)for(let[n,g]of Object.entries(e.dependencies))typeof g=="string"&&g.startsWith("workspace:")&&o[n]&&(e.dependencies[n]=`^${o[n]}`,a=!0,console.log(` \u{1F4E6} Updated ${n}: workspace:* \u2192 ^${o[n]}`));a?(p.writeFileSync(t,JSON.stringify(e,null,2)+`
|
|
29
|
-
`),console.log("\u2705 Package.json updated with actual package versions!")):console.log("\u{1F4C4} No workspace dependencies found to update")}catch(e){console.log(`\u274C Error updating package.json: ${e}`)}}
|
|
15
|
+
`);let o=r.opts();if(["langgraphPy","langgraphJs","crewaiFlows","mastra","ag2","llamaindex","pydanticAi","agno"].some(n=>o[n])){await p();return}else console.log(""),console.log("To build an AG-UI app, you need to select a client."),console.log("");switch((await i.prompt([{type:"list",name:"client",message:"What client do you want to use?",choices:["CopilotKit/Next.js","CLI client",new i.Separator(" Other clients coming soon (SMS, Whatsapp, Slack ...)")]}])).client){case"CopilotKit/Next.js":await p();break;case"CLI client":await j();break;default:break}}async function p(){let o=r.opts(),e=[],t=await i.prompt([{type:"input",name:"name",message:"What would you like to name your project?",default:"my-ag-ui-app",validate:a=>a.trim()?/^[a-zA-Z0-9-_]+$/.test(a)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);o.langgraphPy?e.push("-f","langgraph-py"):o.langgraphJs?e.push("-f","langgraph-js"):o.crewiAiFlows?e.push("-f","flows"):o.mastra?e.push("-f","mastra"):o.ag2?e.push("-f","ag2"):o.llamaindex?e.push("-f","llamaindex"):o.agno?e.push("-f","agno"):o.pydanticAi&&e.push("-f","pydantic-ai"),m("npx",["copilotkit@latest","create","--no-banner","-n",t.name,...e],{stdio:"inherit",shell:!0}).on("close",a=>{a!==0&&console.log(`
|
|
16
|
+
\u274C Project creation failed.`)})}async function j(){console.log(`\u{1F527} Setting up CLI client...
|
|
17
|
+
`),console.log("\u{1F50D} Reading current package versions...");let o=await P();console.log(`\u{1F4CB} Found versions: ${Object.keys(o).length} packages`),Object.entries(o).forEach(([t,n])=>{console.log(` - ${t}: ${n}`)}),console.log("");let e=await i.prompt([{type:"input",name:"name",message:"What would you like to name your CLI project?",default:"my-ag-ui-cli-app",validate:t=>t.trim()?/^[a-zA-Z0-9-_]+$/.test(t)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);try{console.log(`\u{1F4E5} Downloading CLI client template: ${e.name}
|
|
18
|
+
`),await f("gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example",{dir:e.name,install:!1}),console.log("\u2705 CLI client template downloaded successfully!"),console.log(`
|
|
19
|
+
\u{1F504} Updating workspace dependencies...`),await $(e.name,o),console.log(`
|
|
20
|
+
\u{1F4C1} Project created in: ${e.name}`),console.log(`
|
|
21
|
+
\u{1F680} Next steps:`),console.log(" export OPENAI_API_KEY='your-openai-api-key'"),console.log(` cd ${e.name}`),console.log(" npm install"),console.log(" npm run dev"),console.log(`
|
|
22
|
+
\u{1F4A1} Check the README.md for more information on how to use your CLI client!`)}catch(t){console.log("\u274C Failed to download CLI client template:",t),process.exit(1)}}r.name("create-ag-ui-app").description(y).version("0.0.36");r.option("--langgraph-py","Use the LangGraph framework with Python").option("--langgraph-js","Use the LangGraph framework with JavaScript").option("--crewai-flows","Use the CrewAI framework with Flows").option("--mastra","Use the Mastra framework").option("--pydantic-ai","Use the Pydantic AI framework").option("--llamaindex","Use the LlamaIndex framework").option("--agno","Use the Agno framework").option("--ag2","Use the AG2 framework");r.action(async()=>{await k()});r.parse();async function P(){var t;let o=["@ag-ui/client","@ag-ui/core","@ag-ui/mastra"],e={};for(let n of o)try{let a=await fetch(`https://registry.npmjs.org/${n}`);if(a.ok){let s=await a.json();e[n]=((t=s["dist-tags"])==null?void 0:t.latest)||"latest",console.log(` \u2713 ${n}: ${e[n]}`)}else console.log(` \u26A0\uFE0F Could not fetch version for ${n}`),e[n]="latest"}catch(a){console.log(` \u26A0\uFE0F Error fetching ${n}: ${a}`),e[n]="latest"}return e}async function $(o,e){let t=d.join(o,"package.json");try{if(!c.existsSync(t)){console.log("\u26A0\uFE0F No package.json found in downloaded project");return}let n=JSON.parse(c.readFileSync(t,"utf-8")),a=!1;if(n.dependencies)for(let[s,l]of Object.entries(n.dependencies))typeof l=="string"&&l.startsWith("workspace:")&&e[s]&&(n.dependencies[s]=`^${e[s]}`,a=!0,console.log(` \u{1F4E6} Updated ${s}: workspace:* \u2192 ^${e[s]}`));a?(c.writeFileSync(t,JSON.stringify(n,null,2)+`
|
|
23
|
+
`),console.log("\u2705 Package.json updated with actual package versions!")):console.log("\u{1F4C4} No workspace dependencies found to update")}catch(n){console.log(`\u274C Error updating package.json: ${n}`)}}
|
|
30
24
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport inquirer from \"inquirer\";\nimport { spawn } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { downloadTemplate } from \"giget\";\n\nconst program = new Command();\n\n// Dark purple color\nconst PURPLE = \"\\x1b[35m\";\nconst RESET = \"\\x1b[0m\";\n\nfunction displayBanner() {\n const banner = `\n${PURPLE} āāāāāā āāāāāāā āāā āāā āāā\n āāāāāāāāāāāāāāāā āāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāā āāā āāā\n āāā āāāāāāāāāāāā āāāāāāāāā āāā\n āāā āāā āāāāāāā āāāāāāā āāā\n${RESET}\n Agent User Interactivity Protocol\n`;\n console.log(banner);\n}\n\nasync function createProject() {\n displayBanner();\n\n console.log(\"\\n~ Let's get started building an AG-UI powered user interactive agent ~\");\n console.log(\" Read more about AG-UI at https://ag-ui.com\\n\");\n console.log(\"\");\n console.log(\"To build an AG-UI app, you need to select a client.\");\n console.log(\"\");\n\n const answers = await inquirer.prompt([\n {\n type: \"list\",\n name: \"client\",\n message: \"What client do you want to use?\",\n choices: [\n \"CopilotKit/Next.js\",\n \"CLI client\",\n new inquirer.Separator(\"Other clients coming soon (SMS, Whatsapp, Slack ...)\"),\n ],\n },\n ]);\n\n console.log(`\\nSelected client: ${answers.client}`);\n console.log(\"Initializing your project...\\n\");\n\n // Handle CLI client option\n if (answers.client === \"CLI client\") {\n await handleCliClient();\n return;\n }\n\n // Continue with existing CopilotKit/Next.js logic\n const packageJsonPath = path.join(process.cwd(), \"package.json\");\n const packageJsonExists = fs.existsSync(packageJsonPath);\n\n let projectDir = process.cwd();\n\n if (!packageJsonExists) {\n console.log(\"š¦ No package.json found, creating a new Next.js app...\\n\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your project?\",\n default: \"my-ag-ui-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n projectDir = path.join(process.cwd(), projectName.name);\n\n console.log(`Creating Next.js app: ${projectName.name}\\n`);\n\n const createNextApp = spawn(\n \"npx\",\n [\n \"create-next-app@latest\",\n projectName.name,\n \"--typescript\",\n \"--tailwind\",\n \"--eslint\",\n \"--app\",\n \"--src-dir\",\n \"--import-alias\",\n \"@/*\",\n \"--no-turbopack\",\n ],\n {\n stdio: \"inherit\",\n shell: true,\n },\n );\n\n await new Promise<void>((resolve, reject) => {\n createNextApp.on(\"close\", (code) => {\n if (code === 0) {\n console.log(\"\\nā
Next.js app created successfully!\");\n resolve();\n } else {\n console.log(\"\\nā Failed to create Next.js app\");\n reject(new Error(`create-next-app exited with code ${code}`));\n }\n });\n });\n\n // Change to the new project directory\n try {\n process.chdir(projectDir);\n } catch (error) {\n console.log(\"ā Error changing directory:\", error);\n process.exit(1);\n }\n }\n\n // Run copilotkit init with framework flags\n console.log(\"\\nš Running CopilotKit initialization...\\n\");\n\n const options = program.opts();\n const frameworkArgs = [];\n\n if (options.langgraph) {\n frameworkArgs.push(\"-m\", \"LangGraph\");\n } else if (options.crewiAiCrews) {\n frameworkArgs.push(\"-m\", \"CrewAI\", \"--crew-type\", \"Crews\");\n } else if (options.crewiAiFlows) {\n frameworkArgs.push(\"-m\", \"CrewAI\", \"--crew-type\", \"Flows\");\n } else if (options.mastra) {\n frameworkArgs.push(\"-m\", \"Mastra\");\n } else if (options.ag2) {\n frameworkArgs.push(\"-m\", \"AG2\");\n } else if (options.llamaindex) {\n frameworkArgs.push(\"-m\", \"LlamaIndex\");\n } else if (options.agno) {\n frameworkArgs.push(\"-m\", \"Agno\");\n }\n\n const copilotkit = spawn(\"npx\", [\"copilotkit\", \"init\", ...frameworkArgs], {\n stdio: \"inherit\",\n shell: true,\n });\n\n copilotkit.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(\"\\nā Project creation failed.\");\n }\n });\n}\n\nasync function handleCliClient() {\n console.log(\"š§ Setting up CLI client...\\n\");\n\n // Get current package versions from the monorepo\n console.log(\"š Reading current package versions...\");\n const versions = await getCurrentPackageVersions();\n console.log(`š Found versions: ${Object.keys(versions).length} packages`);\n Object.entries(versions).forEach(([name, version]) => {\n console.log(` - ${name}: ${version}`);\n });\n console.log(\"\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your CLI project?\",\n default: \"my-ag-ui-cli-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n try {\n console.log(`š„ Downloading CLI client template: ${projectName.name}\\n`);\n\n await downloadTemplate(\"gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example\", {\n dir: projectName.name,\n install: false,\n });\n\n console.log(\"ā
CLI client template downloaded successfully!\");\n\n // Update workspace dependencies with actual versions\n console.log(\"\\nš Updating workspace dependencies...\");\n await updateWorkspaceDependencies(projectName.name, versions);\n\n console.log(`\\nš Project created in: ${projectName.name}`);\n console.log(\"\\nš Next steps:\");\n console.log(\" export OPENAI_API_KEY='your-openai-api-key'\");\n console.log(` cd ${projectName.name}`);\n console.log(\" npm install\");\n console.log(\" npm run dev\");\n console.log(\"\\nš” Check the README.md for more information on how to use your CLI client!\");\n } catch (error) {\n console.log(\"ā Failed to download CLI client template:\", error);\n process.exit(1);\n }\n}\n\nprogram.name(\"create-ag-ui-app\").description(\"AG-UI CLI\").version(\"0.0.1-alpha.1\");\n\n// Add framework flags\nprogram\n .option(\"--langgraph\", \"Use the LangGraph framework\")\n .option(\"--crewi-ai-crews\", \"Use the CrewAI framework with Crews\")\n .option(\"--crewi-ai-flows\", \"Use the CrewAI framework with Flows\")\n .option(\"--mastra\", \"Use the Mastra framework\")\n .option(\"--ag2\", \"Use the AG2 framework\")\n .option(\"--llamaindex\", \"Use the LlamaIndex framework\")\n .option(\"--agno\", \"Use the Agno framework\");\n\nprogram.action(async () => {\n await createProject();\n});\n\nprogram.parse();\n\n// Utility functions\n\n// Helper function to get package versions from npmjs\nasync function getCurrentPackageVersions(): Promise<{ [key: string]: string }> {\n const packages = [\"@ag-ui/client\", \"@ag-ui/core\", \"@ag-ui/mastra\"];\n const versions: { [key: string]: string } = {};\n\n for (const packageName of packages) {\n try {\n // Fetch package info from npm registry\n const response = await fetch(`https://registry.npmjs.org/${packageName}`);\n if (response.ok) {\n const packageInfo = await response.json();\n versions[packageName] = packageInfo[\"dist-tags\"]?.latest || \"latest\";\n console.log(` ā ${packageName}: ${versions[packageName]}`);\n } else {\n console.log(` ā ļø Could not fetch version for ${packageName}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n } catch (error) {\n console.log(` ā ļø Error fetching ${packageName}: ${error}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n }\n\n return versions;\n}\n\n// Function to update workspace dependencies in downloaded project\nasync function updateWorkspaceDependencies(\n projectPath: string,\n versions: { [key: string]: string },\n) {\n const packageJsonPath = path.join(projectPath, \"package.json\");\n\n try {\n if (!fs.existsSync(packageJsonPath)) {\n console.log(\"ā ļø No package.json found in downloaded project\");\n return;\n }\n\n const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n let updated = false;\n\n // Update workspace dependencies with actual versions\n if (packageJson.dependencies) {\n for (const [depName, depVersion] of Object.entries(packageJson.dependencies)) {\n if (\n typeof depVersion === \"string\" &&\n depVersion.startsWith(\"workspace:\") &&\n versions[depName]\n ) {\n packageJson.dependencies[depName] = `^${versions[depName]}`;\n updated = true;\n console.log(` š¦ Updated ${depName}: workspace:* ā ^${versions[depName]}`);\n }\n }\n }\n\n if (updated) {\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n console.log(\"ā
Package.json updated with actual package versions!\");\n } else {\n console.log(\"š No workspace dependencies found to update\");\n }\n } catch (error) {\n console.log(`ā Error updating package.json: ${error}`);\n }\n}\n"],"mappings":"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","names":["Command","inquirer","spawn","fs","path","downloadTemplate","program","PURPLE","RESET","displayBanner","banner","createProject","answers","handleCliClient","packageJsonPath","packageJsonExists","projectDir","projectName","input","createNextApp","resolve","reject","code","error","options","frameworkArgs","versions","getCurrentPackageVersions","name","version","updateWorkspaceDependencies","_a","packages","packageName","response","packageInfo","projectPath","packageJson","updated","depName","depVersion"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport inquirer from \"inquirer\";\nimport { spawn } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { downloadTemplate } from \"giget\";\n\nconst program = new Command();\n\n// Dark purple color\nconst PURPLE = \"\\x1b[35m\";\nconst RESET = \"\\x1b[0m\";\n\nfunction displayBanner() {\n const banner = `\n${PURPLE} āāāāāā āāāāāāā āāā āāā āāā\n āāāāāāāāāāāāāāāā āāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāāā āāā āāā\n āāāāāāāāāāā āāāāāāāāāāāā āāā āāā\n āāā āāāāāāāāāāāā āāāāāāāāā āāā\n āāā āāā āāāāāāā āāāāāāā āāā\n${RESET}\n Agent User Interactivity Protocol\n`;\n console.log(banner);\n}\n\nconst description = `\nQuickly scaffold AG-UI enabled applications for your favorite agent frameworks.\n`\n\nasync function createProject() {\n displayBanner();\n\n console.log(\"\\n~ Let's get started building an AG-UI powered user interactive agent ~\");\n console.log(\" Read more about AG-UI at https://ag-ui.com\\n\");\n\n const options = program.opts();\n const isFrameworkDefined = [\n \"langgraphPy\",\n \"langgraphJs\",\n \"crewaiFlows\",\n \"mastra\",\n \"ag2\",\n \"llamaindex\",\n \"pydanticAi\",\n \"agno\"\n ].some(flag => options[flag]);\n\n if (isFrameworkDefined) {\n await handleCopilotKitNextJs();\n return;\n } else {\n console.log(\"\");\n console.log(\"To build an AG-UI app, you need to select a client.\");\n console.log(\"\");\n }\n\n const answers = await inquirer.prompt([\n {\n type: \"list\",\n name: \"client\",\n message: \"What client do you want to use?\",\n choices: [\n \"CopilotKit/Next.js\",\n \"CLI client\",\n new inquirer.Separator(\" Other clients coming soon (SMS, Whatsapp, Slack ...)\"),\n ],\n },\n ]);\n\n switch (answers.client) {\n case \"CopilotKit/Next.js\":\n await handleCopilotKitNextJs();\n break;\n case \"CLI client\":\n await handleCliClient();\n break;\n default:\n break;\n }\n}\n\nasync function handleCopilotKitNextJs() {\n const options = program.opts();\n const frameworkArgs: string[] = [];\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your project?\",\n default: \"my-ag-ui-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n // Translate options to CopilotKit framework flags\n if (options.langgraphPy) {\n frameworkArgs.push(\"-f\", \"langgraph-py\");\n } else if (options.langgraphJs) {\n frameworkArgs.push(\"-f\", \"langgraph-js\");\n } else if (options.crewiAiFlows) {\n frameworkArgs.push(\"-f\", \"flows\");\n } else if (options.mastra) {\n frameworkArgs.push(\"-f\", \"mastra\");\n } else if (options.ag2) {\n frameworkArgs.push(\"-f\", \"ag2\");\n } else if (options.llamaindex) {\n frameworkArgs.push(\"-f\", \"llamaindex\");\n } else if (options.agno) {\n frameworkArgs.push(\"-f\", \"agno\");\n } else if (options.pydanticAi) {\n frameworkArgs.push(\"-f\", \"pydantic-ai\");\n }\n\n const copilotkit = spawn(\"npx\", \n [\n \"copilotkit@latest\",\n \"create\",\n \"--no-banner\",\n \"-n\", projectName.name,\n ...frameworkArgs,\n ],\n {\n stdio: \"inherit\",\n shell: true,\n },\n );\n\n copilotkit.on(\"close\", (code) => {\n if (code !== 0) {\n console.log(\"\\nā Project creation failed.\");\n }\n });\n}\n\nasync function handleCliClient() {\n console.log(\"š§ Setting up CLI client...\\n\");\n\n // Get current package versions from the monorepo\n console.log(\"š Reading current package versions...\");\n const versions = await getCurrentPackageVersions();\n console.log(`š Found versions: ${Object.keys(versions).length} packages`);\n Object.entries(versions).forEach(([name, version]) => {\n console.log(` - ${name}: ${version}`);\n });\n console.log(\"\");\n\n const projectName = await inquirer.prompt([\n {\n type: \"input\",\n name: \"name\",\n message: \"What would you like to name your CLI project?\",\n default: \"my-ag-ui-cli-app\",\n validate: (input) => {\n if (!input.trim()) {\n return \"Project name cannot be empty\";\n }\n if (!/^[a-zA-Z0-9-_]+$/.test(input)) {\n return \"Project name can only contain letters, numbers, hyphens, and underscores\";\n }\n return true;\n },\n },\n ]);\n\n try {\n console.log(`š„ Downloading CLI client template: ${projectName.name}\\n`);\n\n await downloadTemplate(\"gh:ag-ui-protocol/ag-ui/typescript-sdk/apps/client-cli-example\", {\n dir: projectName.name,\n install: false,\n });\n\n console.log(\"ā
CLI client template downloaded successfully!\");\n\n // Update workspace dependencies with actual versions\n console.log(\"\\nš Updating workspace dependencies...\");\n await updateWorkspaceDependencies(projectName.name, versions);\n\n console.log(`\\nš Project created in: ${projectName.name}`);\n console.log(\"\\nš Next steps:\");\n console.log(\" export OPENAI_API_KEY='your-openai-api-key'\");\n console.log(` cd ${projectName.name}`);\n console.log(\" npm install\");\n console.log(\" npm run dev\");\n console.log(\"\\nš” Check the README.md for more information on how to use your CLI client!\");\n } catch (error) {\n console.log(\"ā Failed to download CLI client template:\", error);\n process.exit(1);\n }\n}\n\n// Metadata\nprogram\n .name(\"create-ag-ui-app\")\n .description(description)\n .version(\"0.0.36\");\n\n// Add framework flags\nprogram\n .option(\"--langgraph-py\", \"Use the LangGraph framework with Python\")\n .option(\"--langgraph-js\", \"Use the LangGraph framework with JavaScript\")\n .option(\"--crewai-flows\", \"Use the CrewAI framework with Flows\")\n .option(\"--mastra\", \"Use the Mastra framework\")\n .option(\"--pydantic-ai\", \"Use the Pydantic AI framework\")\n .option(\"--llamaindex\", \"Use the LlamaIndex framework\")\n .option(\"--agno\", \"Use the Agno framework\")\n .option(\"--ag2\", \"Use the AG2 framework\")\n\nprogram.action(async () => {\n await createProject();\n});\n\nprogram.parse();\n\n// Utility functions\n\n// Helper function to get package versions from npmjs\nasync function getCurrentPackageVersions(): Promise<{ [key: string]: string }> {\n const packages = [\"@ag-ui/client\", \"@ag-ui/core\", \"@ag-ui/mastra\"];\n const versions: { [key: string]: string } = {};\n\n for (const packageName of packages) {\n try {\n // Fetch package info from npm registry\n const response = await fetch(`https://registry.npmjs.org/${packageName}`);\n if (response.ok) {\n const packageInfo = await response.json();\n versions[packageName] = packageInfo[\"dist-tags\"]?.latest || \"latest\";\n console.log(` ā ${packageName}: ${versions[packageName]}`);\n } else {\n console.log(` ā ļø Could not fetch version for ${packageName}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n } catch (error) {\n console.log(` ā ļø Error fetching ${packageName}: ${error}`);\n // Fallback to latest\n versions[packageName] = \"latest\";\n }\n }\n\n return versions;\n}\n\n// Function to update workspace dependencies in downloaded project\nasync function updateWorkspaceDependencies(\n projectPath: string,\n versions: { [key: string]: string },\n) {\n const packageJsonPath = path.join(projectPath, \"package.json\");\n\n try {\n if (!fs.existsSync(packageJsonPath)) {\n console.log(\"ā ļø No package.json found in downloaded project\");\n return;\n }\n\n const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"));\n let updated = false;\n\n // Update workspace dependencies with actual versions\n if (packageJson.dependencies) {\n for (const [depName, depVersion] of Object.entries(packageJson.dependencies)) {\n if (\n typeof depVersion === \"string\" &&\n depVersion.startsWith(\"workspace:\") &&\n versions[depName]\n ) {\n packageJson.dependencies[depName] = `^${versions[depName]}`;\n updated = true;\n console.log(` š¦ Updated ${depName}: workspace:* ā ^${versions[depName]}`);\n }\n }\n }\n\n if (updated) {\n fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n console.log(\"ā
Package.json updated with actual package versions!\");\n } else {\n console.log(\"š No workspace dependencies found to update\");\n }\n } catch (error) {\n console.log(`ā Error updating package.json: ${error}`);\n }\n}\n"],"mappings":";AACA,OAAS,WAAAA,MAAe,YACxB,OAAOC,MAAc,WACrB,OAAS,SAAAC,MAAa,gBACtB,OAAOC,MAAQ,KACf,OAAOC,MAAU,OACjB,OAAS,oBAAAC,MAAwB,QAEjC,IAAMC,EAAU,IAAIN,EAGdO,EAAS,WACTC,EAAQ,UAEd,SAASC,GAAgB,CACvB,IAAMC,EAAS;AAAA,EACfH,CAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMNC,CAAK;AAAA;AAAA,EAGL,QAAQ,IAAIE,CAAM,CACpB,CAEA,IAAMC,EAAc;AAAA;AAAA,EAIpB,eAAeC,GAAgB,CAC7BH,EAAc,EAEd,QAAQ,IAAI;AAAA,uEAA0E,EACtF,QAAQ,IAAI;AAAA,CAAgD,EAE5D,IAAMI,EAAUP,EAAQ,KAAK,EAY7B,GAX2B,CACzB,cACA,cACA,cACA,SACA,MACA,aACA,aACA,MACF,EAAE,KAAKQ,GAAQD,EAAQC,CAAI,CAAC,EAEJ,CACtB,MAAMC,EAAuB,EAC7B,MACF,MACE,QAAQ,IAAI,EAAE,EACd,QAAQ,IAAI,qDAAqD,EACjE,QAAQ,IAAI,EAAE,EAgBhB,QAbgB,MAAMd,EAAS,OAAO,CACpC,CACE,KAAM,OACN,KAAM,SACN,QAAS,kCACT,QAAS,CACP,qBACA,aACA,IAAIA,EAAS,UAAU,uDAAuD,CAChF,CACF,CACF,CAAC,GAEe,OAAQ,CACtB,IAAK,qBACH,MAAMc,EAAuB,EAC7B,MACF,IAAK,aACH,MAAMC,EAAgB,EACtB,MACF,QACE,KACJ,CACF,CAEA,eAAeD,GAAyB,CACtC,IAAMF,EAAUP,EAAQ,KAAK,EACvBW,EAA0B,CAAC,EAE3BC,EAAc,MAAMjB,EAAS,OAAO,CACxC,CACE,KAAM,QACN,KAAM,OACN,QAAS,4CACT,QAAS,eACT,SAAWkB,GACJA,EAAM,KAAK,EAGX,mBAAmB,KAAKA,CAAK,EAG3B,GAFE,2EAHA,8BAOb,CACF,CAAC,EAGGN,EAAQ,YACVI,EAAc,KAAK,KAAM,cAAc,EAC9BJ,EAAQ,YACjBI,EAAc,KAAK,KAAM,cAAc,EAC9BJ,EAAQ,aACjBI,EAAc,KAAK,KAAM,OAAO,EACvBJ,EAAQ,OACjBI,EAAc,KAAK,KAAM,QAAQ,EACxBJ,EAAQ,IACjBI,EAAc,KAAK,KAAM,KAAK,EACrBJ,EAAQ,WACjBI,EAAc,KAAK,KAAM,YAAY,EAC5BJ,EAAQ,KACjBI,EAAc,KAAK,KAAM,MAAM,EACtBJ,EAAQ,YACjBI,EAAc,KAAK,KAAM,aAAa,EAGrBf,EAAM,MACvB,CACE,oBACA,SACA,cACA,KAAMgB,EAAY,KAClB,GAAGD,CACL,EACA,CACE,MAAO,UACP,MAAO,EACT,CACF,EAEW,GAAG,QAAUG,GAAS,CAC3BA,IAAS,GACX,QAAQ,IAAI;AAAA,gCAA8B,CAE9C,CAAC,CACH,CAEA,eAAeJ,GAAkB,CAC/B,QAAQ,IAAI;AAAA,CAA+B,EAG3C,QAAQ,IAAI,+CAAwC,EACpD,IAAMK,EAAW,MAAMC,EAA0B,EACjD,QAAQ,IAAI,6BAAsB,OAAO,KAAKD,CAAQ,EAAE,MAAM,WAAW,EACzE,OAAO,QAAQA,CAAQ,EAAE,QAAQ,CAAC,CAACE,EAAMC,CAAO,IAAM,CACpD,QAAQ,IAAI,OAAOD,CAAI,KAAKC,CAAO,EAAE,CACvC,CAAC,EACD,QAAQ,IAAI,EAAE,EAEd,IAAMN,EAAc,MAAMjB,EAAS,OAAO,CACxC,CACE,KAAM,QACN,KAAM,OACN,QAAS,gDACT,QAAS,mBACT,SAAWkB,GACJA,EAAM,KAAK,EAGX,mBAAmB,KAAKA,CAAK,EAG3B,GAFE,2EAHA,8BAOb,CACF,CAAC,EAED,GAAI,CACF,QAAQ,IAAI,8CAAuCD,EAAY,IAAI;AAAA,CAAI,EAEvE,MAAMb,EAAiB,iEAAkE,CACvF,IAAKa,EAAY,KACjB,QAAS,EACX,CAAC,EAED,QAAQ,IAAI,qDAAgD,EAG5D,QAAQ,IAAI;AAAA,6CAAyC,EACrD,MAAMO,EAA4BP,EAAY,KAAMG,CAAQ,EAE5D,QAAQ,IAAI;AAAA,gCAA4BH,EAAY,IAAI,EAAE,EAC1D,QAAQ,IAAI;AAAA,sBAAkB,EAC9B,QAAQ,IAAI,gDAAgD,EAC5D,QAAQ,IAAI,SAASA,EAAY,IAAI,EAAE,EACvC,QAAQ,IAAI,gBAAgB,EAC5B,QAAQ,IAAI,gBAAgB,EAC5B,QAAQ,IAAI;AAAA,kFAA8E,CAC5F,OAASQ,EAAO,CACd,QAAQ,IAAI,iDAA6CA,CAAK,EAC9D,QAAQ,KAAK,CAAC,CAChB,CACF,CAGApB,EACG,KAAK,kBAAkB,EACvB,YAAYK,CAAW,EACvB,QAAQ,QAAQ,EAGnBL,EACG,OAAO,iBAAkB,yCAAyC,EAClE,OAAO,iBAAkB,6CAA6C,EACtE,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,WAAY,0BAA0B,EAC7C,OAAO,gBAAiB,+BAA+B,EACvD,OAAO,eAAgB,8BAA8B,EACrD,OAAO,SAAU,wBAAwB,EACzC,OAAO,QAAS,uBAAuB,EAE1CA,EAAQ,OAAO,SAAY,CACzB,MAAMM,EAAc,CACtB,CAAC,EAEDN,EAAQ,MAAM,EAKd,eAAegB,GAAgE,CArO/E,IAAAK,EAsOE,IAAMC,EAAW,CAAC,gBAAiB,cAAe,eAAe,EAC3DP,EAAsC,CAAC,EAE7C,QAAWQ,KAAeD,EACxB,GAAI,CAEF,IAAME,EAAW,MAAM,MAAM,8BAA8BD,CAAW,EAAE,EACxE,GAAIC,EAAS,GAAI,CACf,IAAMC,EAAc,MAAMD,EAAS,KAAK,EACxCT,EAASQ,CAAW,IAAIF,EAAAI,EAAY,WAAW,IAAvB,YAAAJ,EAA0B,SAAU,SAC5D,QAAQ,IAAI,YAAOE,CAAW,KAAKR,EAASQ,CAAW,CAAC,EAAE,CAC5D,MACE,QAAQ,IAAI,+CAAqCA,CAAW,EAAE,EAE9DR,EAASQ,CAAW,EAAI,QAE5B,OAASH,EAAO,CACd,QAAQ,IAAI,kCAAwBG,CAAW,KAAKH,CAAK,EAAE,EAE3DL,EAASQ,CAAW,EAAI,QAC1B,CAGF,OAAOR,CACT,CAGA,eAAeI,EACbO,EACAX,EACA,CACA,IAAMY,EAAkB7B,EAAK,KAAK4B,EAAa,cAAc,EAE7D,GAAI,CACF,GAAI,CAAC7B,EAAG,WAAW8B,CAAe,EAAG,CACnC,QAAQ,IAAI,2DAAiD,EAC7D,MACF,CAEA,IAAMC,EAAc,KAAK,MAAM/B,EAAG,aAAa8B,EAAiB,OAAO,CAAC,EACpEE,EAAU,GAGd,GAAID,EAAY,aACd,OAAW,CAACE,EAASC,CAAU,IAAK,OAAO,QAAQH,EAAY,YAAY,EAEvE,OAAOG,GAAe,UACtBA,EAAW,WAAW,YAAY,GAClChB,EAASe,CAAO,IAEhBF,EAAY,aAAaE,CAAO,EAAI,IAAIf,EAASe,CAAO,CAAC,GACzDD,EAAU,GACV,QAAQ,IAAI,uBAAgBC,CAAO,yBAAoBf,EAASe,CAAO,CAAC,EAAE,GAK5ED,GACFhC,EAAG,cAAc8B,EAAiB,KAAK,UAAUC,EAAa,KAAM,CAAC,EAAI;AAAA,CAAI,EAC7E,QAAQ,IAAI,2DAAsD,GAElE,QAAQ,IAAI,qDAA8C,CAE9D,OAASR,EAAO,CACd,QAAQ,IAAI,uCAAkCA,CAAK,EAAE,CACvD,CACF","names":["Command","inquirer","spawn","fs","path","downloadTemplate","program","PURPLE","RESET","displayBanner","banner","description","createProject","options","flag","handleCopilotKitNextJs","handleCliClient","frameworkArgs","projectName","input","code","versions","getCurrentPackageVersions","name","version","updateWorkspaceDependencies","error","_a","packages","packageName","response","packageInfo","projectPath","packageJsonPath","packageJson","updated","depName","depVersion"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-ag-ui-app",
|
|
3
3
|
"author": "Markus Ecker <markus.ecker@gmail.com>",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.37",
|
|
5
5
|
"private": false,
|
|
6
6
|
"publishConfig": {
|
|
7
7
|
"access": "public"
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"scripts": {
|
|
33
33
|
"build": "tsup",
|
|
34
34
|
"dev": "tsup --watch",
|
|
35
|
-
"clean": "rm -rf dist",
|
|
35
|
+
"clean": "rm -rf dist .turbo node_modules",
|
|
36
36
|
"typecheck": "tsc --noEmit",
|
|
37
37
|
"test": "jest",
|
|
38
38
|
"link:global": "pnpm link --global",
|