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 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: options.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 appName = options.appName;
76
- if (!appName && !options.interactive) {
77
- console.error(kleur.red("Please specify an app name or use --interactive"));
78
- process.exit(1);
79
- }
80
- if (!appName && options.interactive) {
81
- const response = await (0, import_prompts.default)({
82
- type: "text",
83
- name: "appName",
84
- message: "What is your app named?",
85
- initial: "my-saas-app",
86
- validate: (value) => {
87
- const validation2 = (0, import_validate_npm_package_name.default)(value);
88
- if (validation2.valid) return true;
89
- return "Invalid app name: " + (validation2.errors?.join(", ") || "unknown error");
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
- appName = response.appName;
93
- }
94
- if (!appName) {
95
- console.error(kleur.red("App name is required"));
96
- process.exit(1);
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.valid) {
100
- console.error(kleur.red(`Invalid app name: ${validation.errors?.join(", ") || "unknown error"}`));
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
- if (options.git) {
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",
@@ -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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-lego-one",
3
- "version": "2.0.6",
3
+ "version": "2.0.9",
4
4
  "description": "Create a new Lego-One SaaS application",
5
5
  "type": "module",
6
6
  "bin": "./dist/index.cjs",