create-ag-ui-app 0.0.40 → 0.0.41-alpha.0
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/LICENSE +18 -5
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/LICENSE
CHANGED
|
@@ -1,8 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
Copyright (c) 2025 Markus Ecker
|
|
1
|
+
MIT License
|
|
3
2
|
|
|
4
|
-
|
|
3
|
+
Copyright (c) 2025
|
|
5
4
|
|
|
6
|
-
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
7
11
|
|
|
8
|
-
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/dist/index.js
CHANGED
|
@@ -15,7 +15,7 @@ Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
|
15
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
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
|
-
`),await(0,h.downloadTemplate)("gh:ag-ui-protocol/ag-ui/
|
|
18
|
+
`),await(0,h.downloadTemplate)("gh:ag-ui-protocol/ag-ui/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(`
|
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/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"]}
|
|
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"]}
|
package/dist/index.mjs
CHANGED
|
@@ -15,7 +15,7 @@ Quickly scaffold AG-UI enabled applications for your favorite agent frameworks.
|
|
|
15
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
|
-
`),await f("gh:ag-ui-protocol/ag-ui/
|
|
18
|
+
`),await f("gh:ag-ui-protocol/ag-ui/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(`
|
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/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"]}
|
|
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":["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"]}
|