create-velox-app 0.6.74 → 0.6.75
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/CHANGELOG.md +6 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.js +39 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +7 -6
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
package/dist/cli.d.ts
CHANGED
|
@@ -6,11 +6,14 @@
|
|
|
6
6
|
* Handles command-line arguments and initiates the scaffolding process.
|
|
7
7
|
*/
|
|
8
8
|
import type { DatabaseType, TemplateType } from './templates/index.js';
|
|
9
|
+
/** Valid package manager types */
|
|
10
|
+
export type PackageManagerType = 'npm' | 'pnpm' | 'yarn';
|
|
9
11
|
/** @internal Exported for testing */
|
|
10
12
|
export interface ParsedArgs {
|
|
11
13
|
projectName?: string;
|
|
12
14
|
template?: TemplateType;
|
|
13
15
|
database?: DatabaseType;
|
|
16
|
+
packageManager?: PackageManagerType;
|
|
14
17
|
help: boolean;
|
|
15
18
|
version: boolean;
|
|
16
19
|
}
|
package/dist/cli.js
CHANGED
|
@@ -39,6 +39,8 @@ Options:
|
|
|
39
39
|
Available: ${getTemplateNames()}
|
|
40
40
|
-d, --database <name> Database to use (default: "sqlite")
|
|
41
41
|
Available: ${getDatabaseNames()}
|
|
42
|
+
--pm <manager> Package manager to use (npm, pnpm, yarn)
|
|
43
|
+
Skips interactive prompt if specified
|
|
42
44
|
-h, --help Show this help message
|
|
43
45
|
-v, --version Show version number
|
|
44
46
|
|
|
@@ -60,8 +62,11 @@ Examples:
|
|
|
60
62
|
npx create-velox-app my-app --auth # Auth template (shortcut)
|
|
61
63
|
npx create-velox-app my-app --rsc -d postgresql # RSC with PostgreSQL
|
|
62
64
|
npx create-velox-app my-app --template=spa # SPA + API template
|
|
65
|
+
npx create-velox-app my-app --pm npm # Non-interactive (npm)
|
|
63
66
|
npx create-velox-app # Prompt for all options
|
|
64
67
|
`;
|
|
68
|
+
/** Valid package managers */
|
|
69
|
+
const VALID_PACKAGE_MANAGERS = new Set(['npm', 'pnpm', 'yarn']);
|
|
65
70
|
/** Template shorthand flags (--auth, --spa, etc.) */
|
|
66
71
|
const TEMPLATE_FLAGS = new Set([
|
|
67
72
|
'--spa',
|
|
@@ -207,6 +212,39 @@ export function parseArgs(args) {
|
|
|
207
212
|
}
|
|
208
213
|
continue;
|
|
209
214
|
}
|
|
215
|
+
// Handle --pm=<value>
|
|
216
|
+
if (arg.startsWith('--pm=')) {
|
|
217
|
+
const value = arg.split('=')[1];
|
|
218
|
+
if (!value) {
|
|
219
|
+
console.error('Error: --pm requires a value. Available: npm, pnpm, yarn');
|
|
220
|
+
process.exit(1);
|
|
221
|
+
}
|
|
222
|
+
if (VALID_PACKAGE_MANAGERS.has(value)) {
|
|
223
|
+
result.packageManager = value;
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
console.error(`Invalid package manager: ${value}. Available: npm, pnpm, yarn`);
|
|
227
|
+
process.exit(1);
|
|
228
|
+
}
|
|
229
|
+
continue;
|
|
230
|
+
}
|
|
231
|
+
// Handle --pm <value>
|
|
232
|
+
if (arg === '--pm') {
|
|
233
|
+
const value = args[i + 1];
|
|
234
|
+
if (!value || value.startsWith('-')) {
|
|
235
|
+
console.error('Error: --pm requires a value. Available: npm, pnpm, yarn');
|
|
236
|
+
process.exit(1);
|
|
237
|
+
}
|
|
238
|
+
if (VALID_PACKAGE_MANAGERS.has(value)) {
|
|
239
|
+
result.packageManager = value;
|
|
240
|
+
i++; // Skip next arg
|
|
241
|
+
}
|
|
242
|
+
else {
|
|
243
|
+
console.error(`Invalid package manager: ${value}. Available: npm, pnpm, yarn`);
|
|
244
|
+
process.exit(1);
|
|
245
|
+
}
|
|
246
|
+
continue;
|
|
247
|
+
}
|
|
210
248
|
// Non-flag argument
|
|
211
249
|
if (!arg.startsWith('-')) {
|
|
212
250
|
if (!result.projectName) {
|
|
@@ -245,7 +283,7 @@ async function main() {
|
|
|
245
283
|
process.exit(0);
|
|
246
284
|
}
|
|
247
285
|
// Run scaffolder
|
|
248
|
-
await createVeloxApp(parsed.projectName, parsed.template, parsed.database);
|
|
286
|
+
await createVeloxApp(parsed.projectName, parsed.template, parsed.database, parsed.packageManager);
|
|
249
287
|
}
|
|
250
288
|
catch (error) {
|
|
251
289
|
// Handle unexpected errors with actionable guidance
|
package/dist/index.d.ts
CHANGED
|
@@ -19,7 +19,7 @@ export declare function isPathSafe(baseDir: string, targetPath: string): boolean
|
|
|
19
19
|
/**
|
|
20
20
|
* Main scaffolding function that creates a new VeloxTS project
|
|
21
21
|
*/
|
|
22
|
-
export declare function createVeloxApp(initialProjectName?: string, initialTemplate?: TemplateType, initialDatabase?: DatabaseType): Promise<void>;
|
|
22
|
+
export declare function createVeloxApp(initialProjectName?: string, initialTemplate?: TemplateType, initialDatabase?: DatabaseType, initialPackageManager?: 'npm' | 'pnpm' | 'yarn'): Promise<void>;
|
|
23
23
|
/**
|
|
24
24
|
* Detect which package manager is being used
|
|
25
25
|
* @internal Exported for testing
|
package/dist/index.js
CHANGED
|
@@ -59,7 +59,7 @@ export function isPathSafe(baseDir, targetPath) {
|
|
|
59
59
|
/**
|
|
60
60
|
* Main scaffolding function that creates a new VeloxTS project
|
|
61
61
|
*/
|
|
62
|
-
export async function createVeloxApp(initialProjectName, initialTemplate, initialDatabase) {
|
|
62
|
+
export async function createVeloxApp(initialProjectName, initialTemplate, initialDatabase, initialPackageManager) {
|
|
63
63
|
// Print welcome banner
|
|
64
64
|
console.log('');
|
|
65
65
|
p.intro(pc.cyan(pc.bold('create-velox-app')));
|
|
@@ -67,7 +67,7 @@ export async function createVeloxApp(initialProjectName, initialTemplate, initia
|
|
|
67
67
|
let projectCreated = false;
|
|
68
68
|
try {
|
|
69
69
|
// Collect project configuration
|
|
70
|
-
const config = await promptProjectConfig(initialProjectName, initialTemplate, initialDatabase);
|
|
70
|
+
const config = await promptProjectConfig(initialProjectName, initialTemplate, initialDatabase, initialPackageManager);
|
|
71
71
|
projectDirectory = config.directory;
|
|
72
72
|
// Show configuration summary
|
|
73
73
|
p.log.info(pc.dim('Configuration:'));
|
|
@@ -127,7 +127,7 @@ export async function createVeloxApp(initialProjectName, initialTemplate, initia
|
|
|
127
127
|
/**
|
|
128
128
|
* Prompt user for project configuration
|
|
129
129
|
*/
|
|
130
|
-
async function promptProjectConfig(initialName, initialTemplate, initialDatabase) {
|
|
130
|
+
async function promptProjectConfig(initialName, initialTemplate, initialDatabase, initialPackageManager) {
|
|
131
131
|
// Project name
|
|
132
132
|
const name = initialName
|
|
133
133
|
? initialName
|
|
@@ -199,10 +199,11 @@ async function promptProjectConfig(initialName, initialTemplate, initialDatabase
|
|
|
199
199
|
throw new Error(`Database "${database}" is not yet available. Please choose SQLite for now.`);
|
|
200
200
|
}
|
|
201
201
|
}
|
|
202
|
-
// Package manager selection (prompt unless running in CI/non-interactive mode)
|
|
203
|
-
let packageManager = detectPackageManager();
|
|
202
|
+
// Package manager selection (prompt unless provided via CLI or running in CI/non-interactive mode)
|
|
203
|
+
let packageManager = initialPackageManager ?? detectPackageManager();
|
|
204
|
+
// Only show package manager prompt if not provided via CLI
|
|
204
205
|
// SKIP_INSTALL is set in smoke tests to skip interactive prompts
|
|
205
|
-
if (process.env.SKIP_INSTALL !== 'true') {
|
|
206
|
+
if (!initialPackageManager && process.env.SKIP_INSTALL !== 'true') {
|
|
206
207
|
const selectedPackageManager = await p.select({
|
|
207
208
|
message: 'Choose a package manager',
|
|
208
209
|
initialValue: packageManager,
|