create-ag-ui-app 0.0.44 → 0.0.45
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.d.mts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +18 -20
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +18 -20
- package/dist/index.mjs.map +1 -1
- package/package.json +21 -10
package/dist/index.d.mts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
export { };
|
package/dist/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
|
|
1
|
+
export { };
|
package/dist/index.js
CHANGED
|
@@ -1,24 +1,22 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
2
|
+
var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`commander`),l=require(`inquirer`);l=s(l);let u=require(`child_process`),d=require(`fs`);d=s(d);let f=require(`path`);f=s(f);let p=require(`giget`);const m=new c.Command;function h(){console.log(`
|
|
3
|
+
\x1B[35m █████╗ ██████╗ ██╗ ██╗ ██╗
|
|
4
|
+
██╔══██╗██╔════╝ ██║ ██║ ██║
|
|
5
|
+
███████║██║ ███╗█████╗██║ ██║ ██║
|
|
6
|
+
██╔══██║██║ ██║╚════╝██║ ██║ ██║
|
|
7
|
+
██║ ██║╚██████╔╝ ╚██████╔╝ ██║
|
|
8
|
+
╚═╝ ╚═╝ ╚═════╝ ╚═════╝ ╚═╝
|
|
9
|
+
\x1B[0m
|
|
10
10
|
Agent User Interactivity Protocol
|
|
11
|
-
|
|
12
|
-
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
13
|
-
`;async function U(){I(),console.log(`
|
|
11
|
+
`)}async function g(){h(),console.log(`
|
|
14
12
|
~ 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
|
|
16
|
-
|
|
17
|
-
`),console.log(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
`),console.log(
|
|
13
|
+
`);let e=m.opts();if([`langgraphPy`,`langgraphJs`,`crewaiFlows`,`mastra`,`ag2`,`llamaindex`,`pydanticAi`,`agno`,`adk`].some(t=>e[t])){await _();return}else console.log(``),console.log(`To build an AG-UI app, you need to select a client.`),console.log(``);switch((await l.default.prompt([{type:`list`,name:`client`,message:`What client do you want to use?`,choices:[`CopilotKit/Next.js`,`CLI client`,new l.default.Separator(` Other clients coming soon (SMS, Whatsapp, Slack ...)`)]}])).client){case`CopilotKit/Next.js`:await _();break;case`CLI client`:await v();break;default:break}}async function _(){let e=m.opts(),t=[],n=await l.default.prompt([{type:`input`,name:`name`,message:`What would you like to name your project?`,default:`my-ag-ui-app`,validate:e=>e.trim()?/^[a-zA-Z0-9-_]+$/.test(e)?!0:`Project name can only contain letters, numbers, hyphens, and underscores`:`Project name cannot be empty`}]);e.langgraphPy?t.push(`-f`,`langgraph-py`):e.langgraphJs?t.push(`-f`,`langgraph-js`):e.crewiAiFlows?t.push(`-f`,`flows`):e.mastra?t.push(`-f`,`mastra`):e.ag2?t.push(`-f`,`ag2`):e.llamaindex?t.push(`-f`,`llamaindex`):e.agno?t.push(`-f`,`agno`):e.pydanticAi?t.push(`-f`,`pydantic-ai`):e.adk&&t.push(`-f`,`adk`),(0,u.spawn)(`npx`,[`copilotkit@latest`,`create`,`--no-banner`,`-n`,n.name,...t],{stdio:`inherit`,shell:!0}).on(`close`,e=>{e!==0&&console.log(`
|
|
14
|
+
❌ Project creation failed.`)})}async function v(){console.log(`🔧 Setting up CLI client...
|
|
15
|
+
`),console.log(`🔍 Reading current package versions...`);let e=await y();console.log(`📋 Found versions: ${Object.keys(e).length} packages`),Object.entries(e).forEach(([e,t])=>{console.log(` - ${e}: ${t}`)}),console.log(``);let t=await l.default.prompt([{type:`input`,name:`name`,message:`What would you like to name your CLI project?`,default:`my-ag-ui-cli-app`,validate:e=>e.trim()?/^[a-zA-Z0-9-_]+$/.test(e)?!0:`Project name can only contain letters, numbers, hyphens, and underscores`:`Project name cannot be empty`}]);try{console.log(`📥 Downloading CLI client template: ${t.name}\n`),await(0,p.downloadTemplate)(`gh:ag-ui-protocol/ag-ui/apps/client-cli-example`,{dir:t.name,install:!1}),console.log(`✅ CLI client template downloaded successfully!`),console.log(`
|
|
16
|
+
🔄 Updating workspace dependencies...`),await b(t.name,e),console.log(`\n📁 Project created in: ${t.name}`),console.log(`
|
|
17
|
+
🚀 Next steps:`),console.log(` export OPENAI_API_KEY='your-openai-api-key'`),console.log(` cd ${t.name}`),console.log(` npm install`),console.log(` npm run dev`),console.log(`
|
|
18
|
+
💡 Check the README.md for more information on how to use your CLI client!`)}catch(e){console.log(`❌ Failed to download CLI client template:`,e),process.exit(1)}}m.name(`create-ag-ui-app`).description(`
|
|
19
|
+
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
20
|
+
`).version(`0.0.36`),m.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`),m.action(async()=>{await g()}),m.parse();async function y(){let e=[`@ag-ui/client`,`@ag-ui/core`,`@ag-ui/mastra`],t={};for(let n of e)try{let e=await fetch(`https://registry.npmjs.org/${n}`);e.ok?(t[n]=(await e.json())[`dist-tags`]?.latest||`latest`,console.log(` ✓ ${n}: ${t[n]}`)):(console.log(` ⚠️ Could not fetch version for ${n}`),t[n]=`latest`)}catch(e){console.log(` ⚠️ Error fetching ${n}: ${e}`),t[n]=`latest`}return t}async function b(e,t){let n=f.default.join(e,`package.json`);try{if(!d.default.existsSync(n)){console.log(`⚠️ No package.json found in downloaded project`);return}let e=JSON.parse(d.default.readFileSync(n,`utf-8`)),r=!1;if(e.dependencies)for(let[n,i]of Object.entries(e.dependencies))typeof i==`string`&&i.startsWith(`workspace:`)&&t[n]&&(e.dependencies[n]=`^${t[n]}`,r=!0,console.log(` 📦 Updated ${n}: workspace:* → ^${t[n]}`));r?(d.default.writeFileSync(n,JSON.stringify(e,null,2)+`
|
|
21
|
+
`),console.log(`✅ Package.json updated with actual package versions!`)):console.log(`📄 No workspace dependencies found to update`)}catch(e){console.log(`❌ Error updating package.json: ${e}`)}}
|
|
24
22
|
//# 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 \"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/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"]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["Command"],"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/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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"}
|
package/dist/index.mjs
CHANGED
|
@@ -1,24 +1,22 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{Command as
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
2
|
+
import{Command as e}from"commander";import t from"inquirer";import{spawn as n}from"child_process";import r from"fs";import i from"path";import{downloadTemplate as a}from"giget";const o=new e;function s(){console.log(`
|
|
3
|
+
\x1B[35m █████╗ ██████╗ ██╗ ██╗ ██╗
|
|
4
|
+
██╔══██╗██╔════╝ ██║ ██║ ██║
|
|
5
|
+
███████║██║ ███╗█████╗██║ ██║ ██║
|
|
6
|
+
██╔══██║██║ ██║╚════╝██║ ██║ ██║
|
|
7
|
+
██║ ██║╚██████╔╝ ╚██████╔╝ ██║
|
|
8
|
+
╚═╝ ╚═╝ ╚═════╝ ╚═════╝ ╚═╝
|
|
9
|
+
\x1B[0m
|
|
10
10
|
Agent User Interactivity Protocol
|
|
11
|
-
|
|
12
|
-
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
13
|
-
`;async function k(){w(),console.log(`
|
|
11
|
+
`)}async function c(){s(),console.log(`
|
|
14
12
|
~ 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
|
|
16
|
-
|
|
17
|
-
`),console.log(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
`),console.log(
|
|
13
|
+
`);let e=o.opts();if([`langgraphPy`,`langgraphJs`,`crewaiFlows`,`mastra`,`ag2`,`llamaindex`,`pydanticAi`,`agno`,`adk`].some(t=>e[t])){await l();return}else console.log(``),console.log(`To build an AG-UI app, you need to select a client.`),console.log(``);switch((await t.prompt([{type:`list`,name:`client`,message:`What client do you want to use?`,choices:[`CopilotKit/Next.js`,`CLI client`,new t.Separator(` Other clients coming soon (SMS, Whatsapp, Slack ...)`)]}])).client){case`CopilotKit/Next.js`:await l();break;case`CLI client`:await u();break;default:break}}async function l(){let e=o.opts(),r=[],i=await t.prompt([{type:`input`,name:`name`,message:`What would you like to name your project?`,default:`my-ag-ui-app`,validate:e=>e.trim()?/^[a-zA-Z0-9-_]+$/.test(e)?!0:`Project name can only contain letters, numbers, hyphens, and underscores`:`Project name cannot be empty`}]);e.langgraphPy?r.push(`-f`,`langgraph-py`):e.langgraphJs?r.push(`-f`,`langgraph-js`):e.crewiAiFlows?r.push(`-f`,`flows`):e.mastra?r.push(`-f`,`mastra`):e.ag2?r.push(`-f`,`ag2`):e.llamaindex?r.push(`-f`,`llamaindex`):e.agno?r.push(`-f`,`agno`):e.pydanticAi?r.push(`-f`,`pydantic-ai`):e.adk&&r.push(`-f`,`adk`),n(`npx`,[`copilotkit@latest`,`create`,`--no-banner`,`-n`,i.name,...r],{stdio:`inherit`,shell:!0}).on(`close`,e=>{e!==0&&console.log(`
|
|
14
|
+
❌ Project creation failed.`)})}async function u(){console.log(`🔧 Setting up CLI client...
|
|
15
|
+
`),console.log(`🔍 Reading current package versions...`);let e=await d();console.log(`📋 Found versions: ${Object.keys(e).length} packages`),Object.entries(e).forEach(([e,t])=>{console.log(` - ${e}: ${t}`)}),console.log(``);let n=await t.prompt([{type:`input`,name:`name`,message:`What would you like to name your CLI project?`,default:`my-ag-ui-cli-app`,validate:e=>e.trim()?/^[a-zA-Z0-9-_]+$/.test(e)?!0:`Project name can only contain letters, numbers, hyphens, and underscores`:`Project name cannot be empty`}]);try{console.log(`📥 Downloading CLI client template: ${n.name}\n`),await a(`gh:ag-ui-protocol/ag-ui/apps/client-cli-example`,{dir:n.name,install:!1}),console.log(`✅ CLI client template downloaded successfully!`),console.log(`
|
|
16
|
+
🔄 Updating workspace dependencies...`),await f(n.name,e),console.log(`\n📁 Project created in: ${n.name}`),console.log(`
|
|
17
|
+
🚀 Next steps:`),console.log(` export OPENAI_API_KEY='your-openai-api-key'`),console.log(` cd ${n.name}`),console.log(` npm install`),console.log(` npm run dev`),console.log(`
|
|
18
|
+
💡 Check the README.md for more information on how to use your CLI client!`)}catch(e){console.log(`❌ Failed to download CLI client template:`,e),process.exit(1)}}o.name(`create-ag-ui-app`).description(`
|
|
19
|
+
Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
20
|
+
`).version(`0.0.36`),o.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`),o.action(async()=>{await c()}),o.parse();async function d(){let e=[`@ag-ui/client`,`@ag-ui/core`,`@ag-ui/mastra`],t={};for(let n of e)try{let e=await fetch(`https://registry.npmjs.org/${n}`);e.ok?(t[n]=(await e.json())[`dist-tags`]?.latest||`latest`,console.log(` ✓ ${n}: ${t[n]}`)):(console.log(` ⚠️ Could not fetch version for ${n}`),t[n]=`latest`)}catch(e){console.log(` ⚠️ Error fetching ${n}: ${e}`),t[n]=`latest`}return t}async function f(e,t){let n=i.join(e,`package.json`);try{if(!r.existsSync(n)){console.log(`⚠️ No package.json found in downloaded project`);return}let e=JSON.parse(r.readFileSync(n,`utf-8`)),i=!1;if(e.dependencies)for(let[n,r]of Object.entries(e.dependencies))typeof r==`string`&&r.startsWith(`workspace:`)&&t[n]&&(e.dependencies[n]=`^${t[n]}`,i=!0,console.log(` 📦 Updated ${n}: workspace:* → ^${t[n]}`));i?(r.writeFileSync(n,JSON.stringify(e,null,2)+`
|
|
21
|
+
`),console.log(`✅ Package.json updated with actual package versions!`)):console.log(`📄 No workspace dependencies found to update`)}catch(e){console.log(`❌ Error updating package.json: ${e}`)}}export{};
|
|
24
22
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport inquirer from \"inquirer\";\nimport { spawn } from \"child_process\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { downloadTemplate } from \"giget\";\n\nconst program = new Command();\n\n// Dark purple color\nconst PURPLE = \"\\x1b[35m\";\nconst RESET = \"\\x1b[0m\";\n\nfunction displayBanner() {\n const banner = `\n${PURPLE} █████╗ ██████╗ ██╗ ██╗ ██╗\n ██╔══██╗██╔════╝ ██║ ██║ ██║\n ███████║██║ ███╗█████╗██║ ██║ ██║\n ██╔══██║██║ ██║╚════╝██║ ██║ ██║\n ██║ ██║╚██████╔╝ ╚██████╔╝ ██║\n ╚═╝ ╚═╝ ╚═════╝ ╚═════╝ ╚═╝\n${RESET}\n Agent User Interactivity Protocol\n`;\n console.log(banner);\n}\n\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/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":";AACA,OAAS,WAAAA,MAAe,YACxB,OAAOC,MAAc,WACrB,OAAS,SAAAC,MAAa,gBACtB,OAAOC,MAAQ,KACf,OAAOC,MAAU,OACjB,OAAS,oBAAAC,MAAwB,QAEjC,IAAMC,EAAU,IAAIN,EAGdO,EAAS,WACTC,EAAQ,UAEd,SAASC,GAAgB,CACvB,IAAMC,EAAS;AAAA,EACfH,CAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMNC,CAAK;AAAA;AAAA,EAGL,QAAQ,IAAIE,CAAM,CACpB,CAEA,IAAMC,EAAc;AAAA;AAAA,EAIpB,eAAeC,GAAgB,CAC7BH,EAAc,EAEd,QAAQ,IAAI;AAAA,uEAA0E,EACtF,QAAQ,IAAI;AAAA,CAAgD,EAE5D,IAAMI,EAAUP,EAAQ,KAAK,EAa7B,GAZ2B,CACzB,cACA,cACA,cACA,SACA,MACA,aACA,aACA,OACA,KACF,EAAE,KAAKQ,GAAQD,EAAQC,CAAI,CAAC,EAEJ,CACtB,MAAMC,EAAuB,EAC7B,MACF,MACE,QAAQ,IAAI,EAAE,EACd,QAAQ,IAAI,qDAAqD,EACjE,QAAQ,IAAI,EAAE,EAgBhB,QAbgB,MAAMd,EAAS,OAAO,CACpC,CACE,KAAM,OACN,KAAM,SACN,QAAS,kCACT,QAAS,CACP,qBACA,aACA,IAAIA,EAAS,UAAU,uDAAuD,CAChF,CACF,CACF,CAAC,GAEe,OAAQ,CACtB,IAAK,qBACH,MAAMc,EAAuB,EAC7B,MACF,IAAK,aACH,MAAMC,EAAgB,EACtB,MACF,QACE,KACJ,CACF,CAEA,eAAeD,GAAyB,CACtC,IAAMF,EAAUP,EAAQ,KAAK,EACvBW,EAA0B,CAAC,EAE3BC,EAAc,MAAMjB,EAAS,OAAO,CACxC,CACE,KAAM,QACN,KAAM,OACN,QAAS,4CACT,QAAS,eACT,SAAWkB,GACJA,EAAM,KAAK,EAGX,mBAAmB,KAAKA,CAAK,EAG3B,GAFE,2EAHA,8BAOb,CACF,CAAC,EAGGN,EAAQ,YACVI,EAAc,KAAK,KAAM,cAAc,EAC9BJ,EAAQ,YACjBI,EAAc,KAAK,KAAM,cAAc,EAC9BJ,EAAQ,aACjBI,EAAc,KAAK,KAAM,OAAO,EACvBJ,EAAQ,OACjBI,EAAc,KAAK,KAAM,QAAQ,EACxBJ,EAAQ,IACjBI,EAAc,KAAK,KAAM,KAAK,EACrBJ,EAAQ,WACjBI,EAAc,KAAK,KAAM,YAAY,EAC5BJ,EAAQ,KACjBI,EAAc,KAAK,KAAM,MAAM,EACtBJ,EAAQ,WACjBI,EAAc,KAAK,KAAM,aAAa,EAC7BJ,EAAQ,KACjBI,EAAc,KAAK,KAAM,KAAK,EAGbf,EAAM,MACvB,CACE,oBACA,SACA,cACA,KAAMgB,EAAY,KAClB,GAAGD,CACL,EACA,CACE,MAAO,UACP,MAAO,EACT,CACF,EAEW,GAAG,QAAUG,GAAS,CAC3BA,IAAS,GACX,QAAQ,IAAI;AAAA,gCAA8B,CAE9C,CAAC,CACH,CAEA,eAAeJ,GAAkB,CAC/B,QAAQ,IAAI;AAAA,CAA+B,EAG3C,QAAQ,IAAI,+CAAwC,EACpD,IAAMK,EAAW,MAAMC,EAA0B,EACjD,QAAQ,IAAI,6BAAsB,OAAO,KAAKD,CAAQ,EAAE,MAAM,WAAW,EACzE,OAAO,QAAQA,CAAQ,EAAE,QAAQ,CAAC,CAACE,EAAMC,CAAO,IAAM,CACpD,QAAQ,IAAI,OAAOD,CAAI,KAAKC,CAAO,EAAE,CACvC,CAAC,EACD,QAAQ,IAAI,EAAE,EAEd,IAAMN,EAAc,MAAMjB,EAAS,OAAO,CACxC,CACE,KAAM,QACN,KAAM,OACN,QAAS,gDACT,QAAS,mBACT,SAAWkB,GACJA,EAAM,KAAK,EAGX,mBAAmB,KAAKA,CAAK,EAG3B,GAFE,2EAHA,8BAOb,CACF,CAAC,EAED,GAAI,CACF,QAAQ,IAAI,8CAAuCD,EAAY,IAAI;AAAA,CAAI,EAEvE,MAAMb,EAAiB,kDAAmD,CACxE,IAAKa,EAAY,KACjB,QAAS,EACX,CAAC,EAED,QAAQ,IAAI,qDAAgD,EAG5D,QAAQ,IAAI;AAAA,6CAAyC,EACrD,MAAMO,EAA4BP,EAAY,KAAMG,CAAQ,EAE5D,QAAQ,IAAI;AAAA,gCAA4BH,EAAY,IAAI,EAAE,EAC1D,QAAQ,IAAI;AAAA,sBAAkB,EAC9B,QAAQ,IAAI,gDAAgD,EAC5D,QAAQ,IAAI,SAASA,EAAY,IAAI,EAAE,EACvC,QAAQ,IAAI,gBAAgB,EAC5B,QAAQ,IAAI,gBAAgB,EAC5B,QAAQ,IAAI;AAAA,kFAA8E,CAC5F,OAASQ,EAAO,CACd,QAAQ,IAAI,iDAA6CA,CAAK,EAC9D,QAAQ,KAAK,CAAC,CAChB,CACF,CAGApB,EACG,KAAK,kBAAkB,EACvB,YAAYK,CAAW,EACvB,QAAQ,QAAQ,EAGnBL,EACG,OAAO,iBAAkB,yCAAyC,EAClE,OAAO,iBAAkB,6CAA6C,EACtE,OAAO,iBAAkB,qCAAqC,EAC9D,OAAO,WAAY,0BAA0B,EAC7C,OAAO,gBAAiB,+BAA+B,EACvD,OAAO,eAAgB,8BAA8B,EACrD,OAAO,SAAU,wBAAwB,EACzC,OAAO,QAAS,uBAAuB,EACvC,OAAO,QAAS,uBAAuB,EAE1CA,EAAQ,OAAO,SAAY,CACzB,MAAMM,EAAc,CACtB,CAAC,EAEDN,EAAQ,MAAM,EAKd,eAAegB,GAAgE,CAzO/E,IAAAK,EA0OE,IAAMC,EAAW,CAAC,gBAAiB,cAAe,eAAe,EAC3DP,EAAsC,CAAC,EAE7C,QAAWQ,KAAeD,EACxB,GAAI,CAEF,IAAME,EAAW,MAAM,MAAM,8BAA8BD,CAAW,EAAE,EACxE,GAAIC,EAAS,GAAI,CACf,IAAMC,EAAc,MAAMD,EAAS,KAAK,EACxCT,EAASQ,CAAW,IAAIF,EAAAI,EAAY,WAAW,IAAvB,YAAAJ,EAA0B,SAAU,SAC5D,QAAQ,IAAI,YAAOE,CAAW,KAAKR,EAASQ,CAAW,CAAC,EAAE,CAC5D,MACE,QAAQ,IAAI,+CAAqCA,CAAW,EAAE,EAE9DR,EAASQ,CAAW,EAAI,QAE5B,OAASH,EAAO,CACd,QAAQ,IAAI,kCAAwBG,CAAW,KAAKH,CAAK,EAAE,EAE3DL,EAASQ,CAAW,EAAI,QAC1B,CAGF,OAAOR,CACT,CAGA,eAAeI,EACbO,EACAX,EACA,CACA,IAAMY,EAAkB7B,EAAK,KAAK4B,EAAa,cAAc,EAE7D,GAAI,CACF,GAAI,CAAC7B,EAAG,WAAW8B,CAAe,EAAG,CACnC,QAAQ,IAAI,2DAAiD,EAC7D,MACF,CAEA,IAAMC,EAAc,KAAK,MAAM/B,EAAG,aAAa8B,EAAiB,OAAO,CAAC,EACpEE,EAAU,GAGd,GAAID,EAAY,aACd,OAAW,CAACE,EAASC,CAAU,IAAK,OAAO,QAAQH,EAAY,YAAY,EAEvE,OAAOG,GAAe,UACtBA,EAAW,WAAW,YAAY,GAClChB,EAASe,CAAO,IAEhBF,EAAY,aAAaE,CAAO,EAAI,IAAIf,EAASe,CAAO,CAAC,GACzDD,EAAU,GACV,QAAQ,IAAI,uBAAgBC,CAAO,yBAAoBf,EAASe,CAAO,CAAC,EAAE,GAK5ED,GACFhC,EAAG,cAAc8B,EAAiB,KAAK,UAAUC,EAAa,KAAM,CAAC,EAAI;AAAA,CAAI,EAC7E,QAAQ,IAAI,2DAAsD,GAElE,QAAQ,IAAI,qDAA8C,CAE9D,OAASR,EAAO,CACd,QAAQ,IAAI,uCAAkCA,CAAK,EAAE,CACvD,CACF","names":["Command","inquirer","spawn","fs","path","downloadTemplate","program","PURPLE","RESET","displayBanner","banner","description","createProject","options","flag","handleCopilotKitNextJs","handleCliClient","frameworkArgs","projectName","input","code","versions","getCurrentPackageVersions","name","version","updateWorkspaceDependencies","error","_a","packages","packageName","response","packageInfo","projectPath","packageJsonPath","packageJson","updated","depName","depVersion"]}
|
|
1
|
+
{"version":3,"file":"index.mjs","names":[],"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/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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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-ag-ui-app",
|
|
3
3
|
"author": "Markus Ecker <markus.ecker@gmail.com>",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.45",
|
|
5
5
|
"private": false,
|
|
6
6
|
"publishConfig": {
|
|
7
7
|
"access": "public"
|
|
@@ -22,19 +22,30 @@
|
|
|
22
22
|
"giget": "2.0.0"
|
|
23
23
|
},
|
|
24
24
|
"devDependencies": {
|
|
25
|
-
"@types/jest": "^29.5.14",
|
|
26
25
|
"@types/node": "^20.11.19",
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"
|
|
26
|
+
"@vitest/coverage-istanbul": "^4.0.18",
|
|
27
|
+
"publint": "^0.3.12",
|
|
28
|
+
"@arethetypeswrong/cli": "^0.17.4",
|
|
29
|
+
"tsdown": "^0.20.1",
|
|
30
|
+
"typescript": "^5.3.3",
|
|
31
|
+
"vitest": "^4.0.18"
|
|
32
|
+
},
|
|
33
|
+
"exports": {
|
|
34
|
+
".": {
|
|
35
|
+
"require": "./dist/index.js",
|
|
36
|
+
"import": "./dist/index.mjs"
|
|
37
|
+
},
|
|
38
|
+
"./package.json": "./package.json"
|
|
31
39
|
},
|
|
32
40
|
"scripts": {
|
|
33
|
-
"build": "
|
|
34
|
-
"dev": "
|
|
35
|
-
"clean": "
|
|
41
|
+
"build": "tsdown",
|
|
42
|
+
"dev": "tsdown --watch",
|
|
43
|
+
"clean": "git clean -fdX --exclude=\"!.env\"",
|
|
36
44
|
"typecheck": "tsc --noEmit",
|
|
37
|
-
"test": "
|
|
45
|
+
"test": "vitest run",
|
|
46
|
+
"test:coverage": "vitest run --coverage",
|
|
47
|
+
"test:watch": "vitest",
|
|
48
|
+
"test:exports": "publint --strict && attw --pack",
|
|
38
49
|
"link:global": "pnpm link --global",
|
|
39
50
|
"unlink:global": "pnpm unlink --global"
|
|
40
51
|
}
|