create-ag-ui-app 0.0.34 → 0.0.36

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 ADDED
@@ -0,0 +1,50 @@
1
+ # create-ag-ui-app
2
+
3
+ CLI tool for scaffolding **Agent-User Interaction (AG-UI) Protocol** applications.
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.
6
+
7
+ Choose from CopilotKit/Next.js for web apps or CLI clients for terminal-based interactions.
8
+
9
+ ## Usage
10
+
11
+ ```bash
12
+ npx create-ag-ui-app@latest
13
+ pnpx create-ag-ui-app@latest
14
+ bunx create-ag-ui-app@latest
15
+ ```
16
+
17
+ ## Features
18
+
19
+ - šŸŽÆ **Interactive setup** – Guided prompts for client and framework selection
20
+ - 🌐 **Multiple clients** – CopilotKit/Next.js web apps and CLI clients
21
+ - šŸ”§ **Framework integration** – Built-in support for LangGraph, CrewAI, Mastra, Agno, LlamaIndex, and more
22
+ - šŸ“¦ **Zero config** – Automatically sets up dependencies and project structure
23
+ - ⚔ **Quick start** – Get from idea to running app in minutes
24
+
25
+ ## Quick example
26
+
27
+ ```bash
28
+ # Interactive setup
29
+ npx create-ag-ui-app@latest
30
+
31
+ # With framework flags
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
37
+ ```
38
+
39
+ ## Documentation
40
+
41
+ - Concepts & architecture: [`docs/concepts`](https://docs.ag-ui.com/concepts/architecture)
42
+ - Full API reference: [`docs/events`](https://docs.ag-ui.com/concepts/events)
43
+
44
+ ## Contributing
45
+
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.
47
+
48
+ ## License
49
+
50
+ MIT Ā© 2025 AG-UI Protocol Contributors
package/dist/index.js CHANGED
@@ -1,30 +1,24 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var x=Object.create;var f=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var I=Object.getOwnPropertyNames;var $=Object.getPrototypeOf,A=Object.prototype.hasOwnProperty;var P=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of I(e))!A.call(o,a)&&a!==t&&f(o,a,{get:()=>e[a],enumerable:!(n=C(e,a))||n.enumerable});return o};var d=(o,e,t)=>(t=o!=null?x($(o)):{},P(e||!o||!o.__esModule?f(t,"default",{value:o,enumerable:!0}):t,o));var h=require("commander"),c=d(require("inquirer")),u=require("child_process"),l=d(require("fs")),g=d(require("path")),y=require("giget"),p=new h.Command,N="\x1B[35m",b="\x1B[0m";function L(){let o=`
3
- ${N} \u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
2
+ "use strict";var w=Object.create;var g=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,$=Object.prototype.hasOwnProperty;var b=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of k(e))!$.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)):{},b(e||!o||!o.__esModule?g(t,"default",{value:o,enumerable:!0}):t,o));var d=require("commander"),i=l(require("inquirer")),u=require("child_process"),c=l(require("fs")),f=l(require("path")),h=require("giget"),r=new d.Command,P="\x1B[35m",C="\x1B[0m";function I(){let o=`
3
+ ${P} \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
- ${b}
9
+ ${C}
10
10
  Agent User Interactivity Protocol
11
- `;console.log(o)}async function U(){L(),console.log(`
11
+ `;console.log(o)}var x=`
12
+ Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
13
+ `;async function A(){I(),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("");let o=await c.default.prompt([{type:"list",name:"client",message:"What client do you want to use?",choices:["CopilotKit/Next.js","CLI client",new c.default.Separator("Other clients coming soon (SMS, Whatsapp, Slack ...)")]}]);if(console.log(`
14
- Selected client: ${o.client}`),console.log(`Initializing your project...
15
- `),o.client==="CLI client"){await E();return}let e=g.default.join(process.cwd(),"package.json"),t=l.default.existsSync(e),n=process.cwd();if(!t){console.log(`\u{1F4E6} No package.json found, creating a new Next.js app...
16
- `);let i=await c.default.prompt([{type:"input",name:"name",message:"What would you like to name your project?",default:"my-ag-ui-app",validate:r=>r.trim()?/^[a-zA-Z0-9-_]+$/.test(r)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);n=g.default.join(process.cwd(),i.name),console.log(`Creating Next.js app: ${i.name}
17
- `);let k=(0,u.spawn)("npx",["create-next-app@latest",i.name,"--typescript","--tailwind","--eslint","--app","--src-dir","--import-alias","@/*","--no-turbopack"],{stdio:"inherit",shell:!0});await new Promise((r,j)=>{k.on("close",w=>{w===0?(console.log(`
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","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"),(0,u.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)}}p.name("create-ag-ui-app").description("AG-UI CLI").version("0.0.1-alpha.1");p.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");p.action(async()=>{await U()});p.parse();async function S(){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 v(o,e){let t=g.default.join(o,"package.json");try{if(!l.default.existsSync(t)){console.log("\u26A0\uFE0F No package.json found in downloaded project");return}let n=JSON.parse(l.default.readFileSync(t,"utf-8")),a=!1;if(n.dependencies)for(let[s,m]of Object.entries(n.dependencies))typeof m=="string"&&m.startsWith("workspace:")&&e[s]&&(n.dependencies[s]=`^${e[s]}`,a=!0,console.log(` \u{1F4E6} Updated ${s}: workspace:* \u2192 ^${e[s]}`));a?(l.default.writeFileSync(t,JSON.stringify(n,null,2)+`
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(x).version("0.0.1-alpha.1");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("--ag2","Use the AG2 framework").option("--llamaindex","Use the LlamaIndex framework").option("--agno","Use the Agno framework");r.action(async()=>{await A()});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=f.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 \"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 }\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.1-alpha.1\");\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(\"--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","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 h}from"commander";import l from"inquirer";import{spawn as u}from"child_process";import p from"fs";import m from"path";import{downloadTemplate as y}from"giget";var c=new h,k="\x1B[35m",j="\x1B[0m";function x(){let s=`
3
- ${k} \u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
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 u}from"giget";var r=new g,f="\x1B[35m",h="\x1B[0m";function w(){let n=`
3
+ ${f} \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
- ${j}
9
+ ${h}
10
10
  Agent User Interactivity Protocol
11
- `;console.log(s)}async function C(){x(),console.log(`
11
+ `;console.log(n)}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("");let s=await l.prompt([{type:"list",name:"client",message:"What client do you want to use?",choices:["CopilotKit/Next.js","CLI client",new l.Separator("Other clients coming soon (SMS, Whatsapp, Slack ...)")]}]);if(console.log(`
14
- Selected client: ${s.client}`),console.log(`Initializing your project...
15
- `),s.client==="CLI client"){await I();return}let o=m.join(process.cwd(),"package.json"),t=p.existsSync(o),e=process.cwd();if(!t){console.log(`\u{1F4E6} No package.json found, creating a new Next.js app...
16
- `);let i=await l.prompt([{type:"input",name:"name",message:"What would you like to name your project?",default:"my-ag-ui-app",validate:r=>r.trim()?/^[a-zA-Z0-9-_]+$/.test(r)?!0:"Project name can only contain letters, numbers, hyphens, and underscores":"Project name cannot be empty"}]);e=m.join(process.cwd(),i.name),console.log(`Creating Next.js app: ${i.name}
17
- `);let w=u("npx",["create-next-app@latest",i.name,"--typescript","--tailwind","--eslint","--app","--src-dir","--import-alias","@/*","--no-turbopack"],{stdio:"inherit",shell:!0});await new Promise((r,f)=>{w.on("close",d=>{d===0?(console.log(`
18
- \u2705 Next.js app created successfully!`),r()):(console.log(`
19
- \u274C Failed to create Next.js app`),f(new Error(`create-next-app exited with code ${d}`)))})});try{process.chdir(e)}catch(r){console.log("\u274C Error changing directory:",r),process.exit(1)}}console.log(`
20
- \u{1F680} Running CopilotKit initialization...
21
- `);let a=c.opts(),n=[];a.langgraph?n.push("-m","LangGraph"):a.crewiAiCrews?n.push("-m","CrewAI","--crew-type","Crews"):a.crewiAiFlows?n.push("-m","CrewAI","--crew-type","Flows"):a.mastra?n.push("-m","Mastra"):a.ag2?n.push("-m","AG2"):a.llamaindex?n.push("-m","LlamaIndex"):a.agno&&n.push("-m","Agno"),u("npx",["copilotkit","init",...n],{stdio:"inherit",shell:!0}).on("close",i=>{i!==0&&console.log(`
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 n=r.opts();if(["langgraphPy","langgraphJs","crewaiFlows","mastra","ag2","llamaindex","agno"].some(o=>n[o])){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 n=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"}]);n.langgraphPy?e.push("-f","langgraph-py"):n.langgraphJs?e.push("-f","langgraph-js"):n.crewiAiFlows?e.push("-f","flows"):n.mastra?e.push("-f","mastra"):n.ag2?e.push("-f","ag2"):n.llamaindex?e.push("-f","llamaindex"):n.agno&&e.push("-f","agno"),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 n=await $();console.log(`\u{1F4CB} Found versions: ${Object.keys(n).length} packages`),Object.entries(n).forEach(([t,o])=>{console.log(` - ${t}: ${o}`)}),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 u("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 b(e.name,n),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.1-alpha.1");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("--ag2","Use the AG2 framework").option("--llamaindex","Use the LlamaIndex framework").option("--agno","Use the Agno framework");r.action(async()=>{await k()});r.parse();async function $(){var t;let n=["@ag-ui/client","@ag-ui/core","@ag-ui/mastra"],e={};for(let o of n)try{let a=await fetch(`https://registry.npmjs.org/${o}`);if(a.ok){let s=await a.json();e[o]=((t=s["dist-tags"])==null?void 0:t.latest)||"latest",console.log(` \u2713 ${o}: ${e[o]}`)}else console.log(` \u26A0\uFE0F Could not fetch version for ${o}`),e[o]="latest"}catch(a){console.log(` \u26A0\uFE0F Error fetching ${o}: ${a}`),e[o]="latest"}return e}async function b(n,e){let t=d.join(n,"package.json");try{if(!c.existsSync(t)){console.log("\u26A0\uFE0F No package.json found in downloaded project");return}let o=JSON.parse(c.readFileSync(t,"utf-8")),a=!1;if(o.dependencies)for(let[s,l]of Object.entries(o.dependencies))typeof l=="string"&&l.startsWith("workspace:")&&e[s]&&(o.dependencies[s]=`^${e[s]}`,a=!0,console.log(` \u{1F4E6} Updated ${s}: workspace:* \u2192 ^${e[s]}`));a?(c.writeFileSync(t,JSON.stringify(o,null,2)+`
23
+ `),console.log("\u2705 Package.json updated with actual package versions!")):console.log("\u{1F4C4} No workspace dependencies found to update")}catch(o){console.log(`\u274C Error updating package.json: ${o}`)}}
30
24
  //# sourceMappingURL=index.mjs.map
@@ -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 \"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 }\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.1-alpha.1\");\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(\"--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","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.34",
4
+ "version": "0.0.36",
5
5
  "private": false,
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -12,8 +12,18 @@
12
12
  "bin": "./dist/index.mjs",
13
13
  "sideEffects": false,
14
14
  "files": [
15
- "dist/**"
15
+ "dist/**",
16
+ "README.md"
16
17
  ],
18
+ "scripts": {
19
+ "build": "tsup",
20
+ "dev": "tsup --watch",
21
+ "clean": "rm -rf dist",
22
+ "typecheck": "tsc --noEmit",
23
+ "test": "jest",
24
+ "link:global": "pnpm link --global",
25
+ "unlink:global": "pnpm unlink --global"
26
+ },
17
27
  "dependencies": {
18
28
  "@types/inquirer": "^9.0.8",
19
29
  "commander": "^12.1.0",
@@ -27,14 +37,5 @@
27
37
  "ts-jest": "^29.1.2",
28
38
  "tsup": "^8.0.2",
29
39
  "typescript": "^5.3.3"
30
- },
31
- "scripts": {
32
- "build": "tsup",
33
- "dev": "tsup --watch",
34
- "clean": "rm -rf dist",
35
- "typecheck": "tsc --noEmit",
36
- "test": "jest",
37
- "link:global": "pnpm link --global",
38
- "unlink:global": "pnpm unlink --global"
39
40
  }
40
- }
41
+ }
package/LICENSE DELETED
@@ -1,8 +0,0 @@
1
- Copyright (c) 2025 Tawkit Inc.
2
- Copyright (c) 2025 Markus Ecker
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
5
-
6
- The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
7
-
8
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.