create-lego-one 2.0.6 → 2.0.9
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.cjs +83 -29
- package/dist/index.cjs.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -49,13 +49,16 @@ async function init() {
|
|
|
49
49
|
const version = getVersion();
|
|
50
50
|
console.log(kleur.gray(`create-lego-one v${version}
|
|
51
51
|
`));
|
|
52
|
-
import_commander.program.name("create-lego-one").description("Create a new Lego-One SaaS application").version(version).argument("[app-name]", "Name of your application").option("-i, --interactive", "Use interactive prompts").option("--git", "Initialize git repository", true).option("--branch <branch>", "Use specific branch").option("--template <template>", "Use specific template").action(async (appName, options) => {
|
|
52
|
+
import_commander.program.name("create-lego-one").description("Create a new Lego-One SaaS application").version(version).argument("[app-name]", "Name of your application").option("-i, --interactive", "Use interactive prompts (default when no app name provided)").option("--no-interactive", "Skip interactive prompts").option("--git", "Initialize git repository", true).option("--no-git", "Skip git initialization").option("--description <description>", "Project description").option("--author <author>", "Author name").option("--branch <branch>", "Use specific branch").option("--template <template>", "Use specific template").action(async (appName, options) => {
|
|
53
|
+
const isInteractive = options.interactive !== false && (!appName || options.interactive === true);
|
|
53
54
|
const opts = {
|
|
54
55
|
appName,
|
|
55
|
-
interactive:
|
|
56
|
-
git: options.git,
|
|
56
|
+
interactive: isInteractive,
|
|
57
|
+
git: options.git !== false,
|
|
57
58
|
branch: options.branch,
|
|
58
|
-
template: options.template
|
|
59
|
+
template: options.template,
|
|
60
|
+
description: options.description,
|
|
61
|
+
author: options.author
|
|
59
62
|
};
|
|
60
63
|
await createApp(opts);
|
|
61
64
|
});
|
|
@@ -72,34 +75,69 @@ function getVersion() {
|
|
|
72
75
|
}
|
|
73
76
|
async function createApp(options) {
|
|
74
77
|
try {
|
|
75
|
-
let
|
|
76
|
-
if (
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
78
|
+
let projectConfig;
|
|
79
|
+
if (options.interactive) {
|
|
80
|
+
const responses = await (0, import_prompts.default)([
|
|
81
|
+
{
|
|
82
|
+
type: "text",
|
|
83
|
+
name: "appName",
|
|
84
|
+
message: "What is your app named?",
|
|
85
|
+
initial: options.appName || "my-saas-app",
|
|
86
|
+
validate: (value) => {
|
|
87
|
+
if (!value) return "App name is required";
|
|
88
|
+
const validation2 = (0, import_validate_npm_package_name.default)(value);
|
|
89
|
+
if (validation2.validForNewPackages) return true;
|
|
90
|
+
const errorMsg = validation2.errors?.join(", ") || validation2.warnings?.join(", ") || "unknown error";
|
|
91
|
+
return "Invalid app name: " + errorMsg;
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
type: "text",
|
|
96
|
+
name: "description",
|
|
97
|
+
message: "Project description (optional)",
|
|
98
|
+
initial: options.description || "A SaaS application built with Lego-One"
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
type: "text",
|
|
102
|
+
name: "author",
|
|
103
|
+
message: "Author name (optional)",
|
|
104
|
+
initial: options.author || ""
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
type: "confirm",
|
|
108
|
+
name: "git",
|
|
109
|
+
message: "Initialize git repository?",
|
|
110
|
+
initial: options.git !== false
|
|
90
111
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
112
|
+
]);
|
|
113
|
+
projectConfig = {
|
|
114
|
+
appName: responses.appName || options.appName || "my-saas-app",
|
|
115
|
+
description: responses.description || options.description || "A SaaS application built with Lego-One",
|
|
116
|
+
author: responses.author || options.author || "",
|
|
117
|
+
git: responses.git !== false
|
|
118
|
+
};
|
|
119
|
+
} else {
|
|
120
|
+
if (!options.appName) {
|
|
121
|
+
console.error(kleur.red("Please specify an app name or use interactive mode (default)"));
|
|
122
|
+
process.exit(1);
|
|
123
|
+
}
|
|
124
|
+
projectConfig = {
|
|
125
|
+
appName: options.appName,
|
|
126
|
+
description: options.description || "A SaaS application built with Lego-One",
|
|
127
|
+
author: options.author || "",
|
|
128
|
+
git: options.git !== false
|
|
129
|
+
};
|
|
97
130
|
}
|
|
98
|
-
const validation = (0, import_validate_npm_package_name.default)(appName);
|
|
99
|
-
if (!validation.
|
|
100
|
-
|
|
131
|
+
const validation = (0, import_validate_npm_package_name.default)(projectConfig.appName);
|
|
132
|
+
if (!validation.validForNewPackages) {
|
|
133
|
+
const errorMsg = validation.errors?.join(", ") || validation.warnings?.join(", ") || "unknown error";
|
|
134
|
+
console.error(kleur.red(`Invalid app name: ${errorMsg}`));
|
|
135
|
+
if (validation.warnings && validation.warnings.length > 0) {
|
|
136
|
+
console.error(kleur.yellow(`Warnings: ${validation.warnings.join(", ")}`));
|
|
137
|
+
}
|
|
101
138
|
process.exit(1);
|
|
102
139
|
}
|
|
140
|
+
const appName = projectConfig.appName;
|
|
103
141
|
const targetDir = import_path.default.resolve(process.cwd(), appName);
|
|
104
142
|
if (await import_fs_extra.default.pathExists(targetDir)) {
|
|
105
143
|
const files = await import_fs_extra.default.readdir(targetDir);
|
|
@@ -118,7 +156,9 @@ async function createApp(options) {
|
|
|
118
156
|
const rootDir = import_path.default.join(__dirname, "../../..");
|
|
119
157
|
await copyTemplateFiles(rootDir, targetDir);
|
|
120
158
|
}
|
|
121
|
-
|
|
159
|
+
console.log(kleur.gray("Configuring project..."));
|
|
160
|
+
await updatePackageJson(targetDir, projectConfig);
|
|
161
|
+
if (projectConfig.git) {
|
|
122
162
|
console.log(kleur.gray("Initializing git repository..."));
|
|
123
163
|
try {
|
|
124
164
|
(0, import_child_process.execSync)("git init", { cwd: targetDir });
|
|
@@ -152,6 +192,20 @@ async function createApp(options) {
|
|
|
152
192
|
process.exit(1);
|
|
153
193
|
}
|
|
154
194
|
}
|
|
195
|
+
async function updatePackageJson(targetDir, config) {
|
|
196
|
+
const packageJsonPath = import_path.default.join(targetDir, "package.json");
|
|
197
|
+
if (await import_fs_extra.default.pathExists(packageJsonPath)) {
|
|
198
|
+
const packageJson = JSON.parse(await import_fs_extra.default.readFile(packageJsonPath, "utf-8"));
|
|
199
|
+
packageJson.name = config.appName;
|
|
200
|
+
if (config.description) {
|
|
201
|
+
packageJson.description = config.description;
|
|
202
|
+
}
|
|
203
|
+
if (config.author) {
|
|
204
|
+
packageJson.author = config.author;
|
|
205
|
+
}
|
|
206
|
+
await import_fs_extra.default.writeFile(packageJsonPath, JSON.stringify(packageJson, null, 2) + "\n", "utf-8");
|
|
207
|
+
}
|
|
208
|
+
}
|
|
155
209
|
async function copyTemplateFiles(sourceDir, targetDir) {
|
|
156
210
|
const filesToCopy = [
|
|
157
211
|
"host",
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../node_modules/.pnpm/tsup@8.5.1_@swc+core@1.15.8_4981d554a2757e4ed25c3ad5a773b01f/node_modules/tsup/assets/cjs_shims.js","../src/index.ts"],"sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n typeof document === \"undefined\" \n ? new URL(`file:${__filename}`).href \n : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n ? document.currentScript.src \n : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","#!/usr/bin/env node\n\n/**\n * create-lego-one CLI\n * Create a new Lego-One SaaS application from template\n */\n\nimport path from 'path';\nimport fs from 'fs';\nimport { fileURLToPath } from 'url';\nimport { program } from 'commander';\nimport * as kleur from 'kleur';\nimport fsExtra from 'fs-extra';\nimport validateProjectName from 'validate-npm-package-name';\nimport prompts from 'prompts';\nimport { execSync } from 'child_process';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\ninterface CreateOptions {\n appName: string;\n interactive: boolean;\n git: boolean;\n branch?: string;\n template?: string;\n}\n\n// ASCII art banner\nconst banner = `\n${kleur.cyan('┌─────────────────────────────────────────────────────────┐')}\n${kleur.cyan('│')} ${kleur.bold().white('Lego-One')} SaaS Boilerplate ${kleur.cyan('│')}\n${kleur.cyan('│')} ${kleur.gray('Microkernel architecture with Modern.js + Garfish')} ${kleur.cyan('│')}\n${kleur.cyan('└─────────────────────────────────────────────────────────┘')}\n`;\n\nasync function init() {\n console.log(banner);\n\n const version = getVersion();\n console.log(kleur.gray(`create-lego-one v${version}\\n`));\n\n program\n .name('create-lego-one')\n .description('Create a new Lego-One SaaS application')\n .version(version)\n .argument('[app-name]', 'Name of your application')\n .option('-i, --interactive', 'Use interactive prompts')\n .option('--git', 'Initialize git repository', true)\n .option('--branch <branch>', 'Use specific branch')\n .option('--template <template>', 'Use specific template')\n .action(async (appName: string, options) => {\n const opts: CreateOptions = {\n appName,\n interactive: options.interactive,\n git: options.git,\n branch: options.branch,\n template: options.template,\n };\n await createApp(opts);\n });\n\n await program.parseAsync(process.argv);\n}\n\nfunction getVersion(): string {\n const pkgPath = path.join(__dirname, '../package.json');\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));\n return pkg.version || '1.0.0';\n } catch {\n return '1.0.0';\n }\n}\n\nasync function createApp(options: CreateOptions) {\n try {\n // Get app name\n let appName = options.appName;\n if (!appName && !options.interactive) {\n console.error(kleur.red('Please specify an app name or use --interactive'));\n process.exit(1);\n }\n\n // Interactive mode for app name\n if (!appName && options.interactive) {\n const response = await prompts({\n type: 'text',\n name: 'appName',\n message: 'What is your app named?',\n initial: 'my-saas-app',\n validate: (value: string) => {\n const validation = validateProjectName(value);\n if (validation.valid) return true;\n return 'Invalid app name: ' + (validation.errors?.join(', ') || 'unknown error');\n },\n });\n appName = response.appName;\n }\n\n if (!appName) {\n console.error(kleur.red('App name is required'));\n process.exit(1);\n }\n\n // Validate app name\n const validation = validateProjectName(appName);\n if (!validation.valid) {\n console.error(kleur.red(`Invalid app name: ${validation.errors?.join(', ') || 'unknown error'}`));\n process.exit(1);\n }\n\n const targetDir = path.resolve(process.cwd(), appName);\n\n // Check if directory exists\n if (await fsExtra.pathExists(targetDir)) {\n const files = await fsExtra.readdir(targetDir);\n if (files.length > 0) {\n console.error(kleur.red(`Directory \"${appName}\" already exists and is not empty`));\n process.exit(1);\n }\n }\n\n console.log(kleur.cyan('Creating your Lego-One application...'));\n\n // Create target directory\n await fsExtra.ensureDir(targetDir);\n\n // Copy template files\n console.log(kleur.gray('Copying template files...'));\n const templateDir = path.join(__dirname, '../template');\n if (await fsExtra.pathExists(templateDir)) {\n await fsExtra.copy(templateDir, targetDir);\n } else {\n // Fallback: copy from root (development mode)\n const rootDir = path.join(__dirname, '../../..');\n await copyTemplateFiles(rootDir, targetDir);\n }\n\n // Initialize git if requested\n if (options.git) {\n console.log(kleur.gray('Initializing git repository...'));\n try {\n execSync('git init', { cwd: targetDir });\n execSync('git add .', { cwd: targetDir });\n execSync('git commit -m \"Initial commit from Lego-One\"', {\n cwd: targetDir,\n });\n } catch (error) {\n console.warn(kleur.yellow('Could not initialize git repository'));\n }\n }\n\n console.log(kleur.green('Application created successfully!'));\n\n // Print success message\n console.log('\\n' + kleur.bold('Next steps:'));\n console.log(` ${kleur.cyan('cd')} ${appName}`);\n console.log(` ${kleur.cyan('pnpm install')}`);\n console.log(` ${kleur.cyan('pnpm run dev')}`);\n console.log('\\n' + kleur.gray('To start developing:'));\n console.log(` ${kleur.cyan('pnpm run dev')} - Start development server`);\n console.log(` ${kleur.cyan('pnpm run dev:all')} - Start all services`);\n console.log('\\n' + kleur.gray('To build for production:'));\n console.log(` ${kleur.cyan('pnpm run build')} - Build application`);\n console.log(` ${kleur.cyan('pnpm run start')} - Start production server`);\n console.log('\\n' + kleur.gray('Documentation:'));\n console.log(` ${kleur.cyan('https://lego-one.dev/docs')} - Full documentation`);\n console.log('\\n' + kleur.yellow('Happy coding! 🚀\\n'));\n } catch (error) {\n console.error(kleur.red('Failed to create application'));\n if (error instanceof Error) {\n console.error(kleur.red(error.message));\n }\n process.exit(1);\n }\n}\n\nasync function copyTemplateFiles(sourceDir: string, targetDir: string) {\n // Files to copy\n const filesToCopy = [\n 'host',\n 'packages/plugins',\n 'package.json',\n 'pnpm-lock.yaml',\n 'pnpm-workspace.yaml',\n '.gitignore',\n 'tsconfig.json',\n ];\n\n // Files to exclude\n const excludePatterns = [\n 'node_modules',\n 'dist',\n '.next',\n 'coverage',\n '.cache',\n '*.log',\n ];\n\n for (const file of filesToCopy) {\n const srcPath = path.join(sourceDir, file);\n const destPath = path.join(targetDir, file);\n\n if (await fsExtra.pathExists(srcPath)) {\n await fsExtra.copy(srcPath, destPath, {\n filter: (src) => {\n const relativePath = path.relative(sourceDir, src);\n return !excludePatterns.some((pattern) =>\n relativePath.includes(pattern)\n );\n },\n });\n }\n }\n}\n\n// Run the CLI\ninit().catch((error) => {\n console.error(kleur.red('Unexpected error:'));\n console.error(error);\n process.exit(1);\n});\n"],"mappings":"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","names":["path","fs","prompts","validation","validateProjectName","fsExtra"]}
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/.pnpm/tsup@8.5.1_@swc+core@1.15.8_4981d554a2757e4ed25c3ad5a773b01f/node_modules/tsup/assets/cjs_shims.js","../src/index.ts"],"sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n typeof document === \"undefined\" \n ? new URL(`file:${__filename}`).href \n : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n ? document.currentScript.src \n : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","#!/usr/bin/env node\n\n/**\n * create-lego-one CLI\n * Create a new Lego-One SaaS application from template\n */\n\nimport path from 'path';\nimport fs from 'fs';\nimport { fileURLToPath } from 'url';\nimport { program } from 'commander';\nimport * as kleur from 'kleur';\nimport fsExtra from 'fs-extra';\nimport validateProjectName from 'validate-npm-package-name';\nimport prompts from 'prompts';\nimport { execSync } from 'child_process';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\ninterface CreateOptions {\n appName?: string;\n interactive: boolean;\n git: boolean;\n branch?: string;\n template?: string;\n description?: string;\n author?: string;\n}\n\ninterface ProjectConfig {\n appName: string;\n description: string;\n author: string;\n git: boolean;\n}\n\n// ASCII art banner\nconst banner = `\n${kleur.cyan('┌─────────────────────────────────────────────────────────┐')}\n${kleur.cyan('│')} ${kleur.bold().white('Lego-One')} SaaS Boilerplate ${kleur.cyan('│')}\n${kleur.cyan('│')} ${kleur.gray('Microkernel architecture with Modern.js + Garfish')} ${kleur.cyan('│')}\n${kleur.cyan('└─────────────────────────────────────────────────────────┘')}\n`;\n\nasync function init() {\n console.log(banner);\n\n const version = getVersion();\n console.log(kleur.gray(`create-lego-one v${version}\\n`));\n\n program\n .name('create-lego-one')\n .description('Create a new Lego-One SaaS application')\n .version(version)\n .argument('[app-name]', 'Name of your application')\n .option('-i, --interactive', 'Use interactive prompts (default when no app name provided)')\n .option('--no-interactive', 'Skip interactive prompts')\n .option('--git', 'Initialize git repository', true)\n .option('--no-git', 'Skip git initialization')\n .option('--description <description>', 'Project description')\n .option('--author <author>', 'Author name')\n .option('--branch <branch>', 'Use specific branch')\n .option('--template <template>', 'Use specific template')\n .action(async (appName: string | undefined, options) => {\n // Default to interactive mode if no app name provided\n const isInteractive = options.interactive !== false && (!appName || options.interactive === true);\n \n const opts: CreateOptions = {\n appName,\n interactive: isInteractive,\n git: options.git !== false,\n branch: options.branch,\n template: options.template,\n description: options.description,\n author: options.author,\n };\n await createApp(opts);\n });\n\n await program.parseAsync(process.argv);\n}\n\nfunction getVersion(): string {\n const pkgPath = path.join(__dirname, '../package.json');\n try {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));\n return pkg.version || '1.0.0';\n } catch {\n return '1.0.0';\n }\n}\n\nasync function createApp(options: CreateOptions) {\n try {\n let projectConfig: ProjectConfig;\n\n // Interactive mode - collect all project information\n if (options.interactive) {\n const responses = await prompts([\n {\n type: 'text',\n name: 'appName',\n message: 'What is your app named?',\n initial: options.appName || 'my-saas-app',\n validate: (value: string) => {\n if (!value) return 'App name is required';\n const validation = validateProjectName(value);\n if (validation.validForNewPackages) return true;\n const errorMsg = validation.errors?.join(', ') || validation.warnings?.join(', ') || 'unknown error';\n return 'Invalid app name: ' + errorMsg;\n },\n },\n {\n type: 'text',\n name: 'description',\n message: 'Project description (optional)',\n initial: options.description || 'A SaaS application built with Lego-One',\n },\n {\n type: 'text',\n name: 'author',\n message: 'Author name (optional)',\n initial: options.author || '',\n },\n {\n type: 'confirm',\n name: 'git',\n message: 'Initialize git repository?',\n initial: options.git !== false,\n },\n ]);\n\n projectConfig = {\n appName: responses.appName || options.appName || 'my-saas-app',\n description: responses.description || options.description || 'A SaaS application built with Lego-One',\n author: responses.author || options.author || '',\n git: responses.git !== false,\n };\n } else {\n // Non-interactive mode - use provided values or defaults\n if (!options.appName) {\n console.error(kleur.red('Please specify an app name or use interactive mode (default)'));\n process.exit(1);\n }\n\n projectConfig = {\n appName: options.appName,\n description: options.description || 'A SaaS application built with Lego-One',\n author: options.author || '',\n git: options.git !== false,\n };\n }\n\n // Validate app name\n const validation = validateProjectName(projectConfig.appName);\n if (!validation.validForNewPackages) {\n const errorMsg = validation.errors?.join(', ') || validation.warnings?.join(', ') || 'unknown error';\n console.error(kleur.red(`Invalid app name: ${errorMsg}`));\n if (validation.warnings && validation.warnings.length > 0) {\n console.error(kleur.yellow(`Warnings: ${validation.warnings.join(', ')}`));\n }\n process.exit(1);\n }\n\n const appName = projectConfig.appName;\n\n const targetDir = path.resolve(process.cwd(), appName);\n\n // Check if directory exists\n if (await fsExtra.pathExists(targetDir)) {\n const files = await fsExtra.readdir(targetDir);\n if (files.length > 0) {\n console.error(kleur.red(`Directory \"${appName}\" already exists and is not empty`));\n process.exit(1);\n }\n }\n\n console.log(kleur.cyan('Creating your Lego-One application...'));\n\n // Create target directory\n await fsExtra.ensureDir(targetDir);\n\n // Copy template files\n console.log(kleur.gray('Copying template files...'));\n const templateDir = path.join(__dirname, '../template');\n if (await fsExtra.pathExists(templateDir)) {\n await fsExtra.copy(templateDir, targetDir);\n } else {\n // Fallback: copy from root (development mode)\n const rootDir = path.join(__dirname, '../../..');\n await copyTemplateFiles(rootDir, targetDir);\n }\n\n // Update package.json with project configuration\n console.log(kleur.gray('Configuring project...'));\n await updatePackageJson(targetDir, projectConfig);\n\n // Initialize git if requested\n if (projectConfig.git) {\n console.log(kleur.gray('Initializing git repository...'));\n try {\n execSync('git init', { cwd: targetDir });\n execSync('git add .', { cwd: targetDir });\n execSync('git commit -m \"Initial commit from Lego-One\"', {\n cwd: targetDir,\n });\n } catch (error) {\n console.warn(kleur.yellow('Could not initialize git repository'));\n }\n }\n\n console.log(kleur.green('Application created successfully!'));\n\n // Print success message\n console.log('\\n' + kleur.bold('Next steps:'));\n console.log(` ${kleur.cyan('cd')} ${appName}`);\n console.log(` ${kleur.cyan('pnpm install')}`);\n console.log(` ${kleur.cyan('pnpm run dev')}`);\n console.log('\\n' + kleur.gray('To start developing:'));\n console.log(` ${kleur.cyan('pnpm run dev')} - Start development server`);\n console.log(` ${kleur.cyan('pnpm run dev:all')} - Start all services`);\n console.log('\\n' + kleur.gray('To build for production:'));\n console.log(` ${kleur.cyan('pnpm run build')} - Build application`);\n console.log(` ${kleur.cyan('pnpm run start')} - Start production server`);\n console.log('\\n' + kleur.gray('Documentation:'));\n console.log(` ${kleur.cyan('https://lego-one.dev/docs')} - Full documentation`);\n console.log('\\n' + kleur.yellow('Happy coding! 🚀\\n'));\n } catch (error) {\n console.error(kleur.red('Failed to create application'));\n if (error instanceof Error) {\n console.error(kleur.red(error.message));\n }\n process.exit(1);\n }\n}\n\nasync function updatePackageJson(targetDir: string, config: ProjectConfig) {\n const packageJsonPath = path.join(targetDir, 'package.json');\n \n if (await fsExtra.pathExists(packageJsonPath)) {\n const packageJson = JSON.parse(await fsExtra.readFile(packageJsonPath, 'utf-8'));\n \n // Update package name\n packageJson.name = config.appName;\n \n // Update description if provided\n if (config.description) {\n packageJson.description = config.description;\n }\n \n // Update author if provided\n if (config.author) {\n packageJson.author = config.author;\n }\n \n // Write updated package.json\n await fsExtra.writeFile(packageJsonPath, JSON.stringify(packageJson, null, 2) + '\\n', 'utf-8');\n }\n}\n\nasync function copyTemplateFiles(sourceDir: string, targetDir: string) {\n // Files to copy\n const filesToCopy = [\n 'host',\n 'packages/plugins',\n 'package.json',\n 'pnpm-lock.yaml',\n 'pnpm-workspace.yaml',\n '.gitignore',\n 'tsconfig.json',\n ];\n\n // Files to exclude\n const excludePatterns = [\n 'node_modules',\n 'dist',\n '.next',\n 'coverage',\n '.cache',\n '*.log',\n ];\n\n for (const file of filesToCopy) {\n const srcPath = path.join(sourceDir, file);\n const destPath = path.join(targetDir, file);\n\n if (await fsExtra.pathExists(srcPath)) {\n await fsExtra.copy(srcPath, destPath, {\n filter: (src) => {\n const relativePath = path.relative(sourceDir, src);\n return !excludePatterns.some((pattern) =>\n relativePath.includes(pattern)\n );\n },\n });\n }\n }\n}\n\n// Run the CLI\ninit().catch((error) => {\n console.error(kleur.red('Unexpected error:'));\n console.error(error);\n process.exit(1);\n});\n"],"mappings":"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","names":["path","fs","prompts","validation","validateProjectName","fsExtra"]}
|