create-ag-ui-app 0.0.40-alpha.3 → 0.0.40

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/dist/index.js CHANGED
@@ -1,24 +1,24 @@
1
1
  #!/usr/bin/env node
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=`
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 m=require("commander"),i=l(require("inquirer")),f=require("child_process"),c=l(require("fs")),u=l(require("path")),h=require("giget"),r=new m.Command,b="\x1B[35m",A="\x1B[0m";function I(){let o=`
3
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
- ${I}
9
+ ${A}
10
10
  Agent User Interactivity Protocol
11
11
  `;console.log(o)}var C=`
12
12
  Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
13
- `;async function x(){A(),console.log(`
13
+ `;async function U(){I(),console.log(`
14
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
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...
15
+ `);let o=r.opts();if(["langgraphPy","langgraphJs","crewaiFlows","mastra","ag2","llamaindex","pydanticAi","agno","adk"].some(n=>o[n])){await d();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 d();break;case"CLI client":await x();break;default:break}}async function d(){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"):o.adk&&e.push("-f","adk"),(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 x(){console.log(`\u{1F527} Setting up CLI client...
17
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
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
19
  \u{1F504} Updating workspace dependencies...`),await L(e.name,o),console.log(`
20
20
  \u{1F4C1} Project created in: ${e.name}`),console.log(`
21
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(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)+`
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").option("--adk","Use the ADK framework");r.action(async()=>{await U()});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)+`
23
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}`)}}
24
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\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"]}
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 \"adk\"\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 } else if (options.adk) {\n frameworkArgs.push(\"-f\", \"adk\");\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 .option(\"--adk\", \"Use the ADK 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,5 +1,5 @@
1
1
  #!/usr/bin/env node
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=`
2
+ import{Command as g}from"commander";import i from"inquirer";import{spawn as d}from"child_process";import c from"fs";import m from"path";import{downloadTemplate as f}from"giget";var r=new g,u="\x1B[35m",h="\x1B[0m";function w(){let o=`
3
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
@@ -12,13 +12,13 @@ ${h}
12
12
  Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
13
13
  `;async function k(){w(),console.log(`
14
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
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(`
15
+ `);let o=r.opts();if(["langgraphPy","langgraphJs","crewaiFlows","mastra","ag2","llamaindex","pydanticAi","agno","adk"].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"):o.adk&&e.push("-f","adk"),d("npx",["copilotkit@latest","create","--no-banner","-n",t.name,...e],{stdio:"inherit",shell:!0}).on("close",a=>{a!==0&&console.log(`
16
16
  \u274C Project creation failed.`)})}async function j(){console.log(`\u{1F527} Setting up CLI client...
17
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
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
19
  \u{1F504} Updating workspace dependencies...`),await $(e.name,o),console.log(`
20
20
  \u{1F4C1} Project created in: ${e.name}`),console.log(`
21
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)+`
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").option("--adk","Use the ADK 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=m.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
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}`)}}
24
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\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":["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"]}
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 \"adk\"\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 } else if (options.adk) {\n frameworkArgs.push(\"-f\", \"adk\");\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 .option(\"--adk\", \"Use the ADK 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.40-alpha.3",
4
+ "version": "0.0.40",
5
5
  "private": false,
6
6
  "publishConfig": {
7
7
  "access": "public"