v0.1.0 #1
@ -1,33 +1,59 @@
|
||||
import type { CommandModule, ArgumentsCamelCase } from 'yargs'
|
||||
import type { CommandModule, Argv, ArgumentsCamelCase } from 'yargs'
|
||||
import c from 'chalk'
|
||||
import { input, select } from '@inquirer/prompts'
|
||||
import clone from 'git-clone'
|
||||
import path from 'node:path'
|
||||
|
||||
// the handler function will be called when our command is executed
|
||||
// it will receive the command line arguments parsed by yargs
|
||||
async function handler() {
|
||||
const folder = await input({
|
||||
message: c.gray('Enter project name:'),
|
||||
default: 'rage-fw',
|
||||
})
|
||||
const framework = await select({
|
||||
message: c.gray('Select frontend:'),
|
||||
default: 'react',
|
||||
loop: true,
|
||||
choices: [
|
||||
{
|
||||
name: 'React + TypeScript (Vite)',
|
||||
value: 'react',
|
||||
description: 'React + TypeScript (Vite) as a frontend',
|
||||
},
|
||||
// {
|
||||
// name: 'vue',
|
||||
// value: 'vue',
|
||||
// description: 'npm is the most popular package manager',
|
||||
// },
|
||||
],
|
||||
})
|
||||
function builder(yargs: Argv) {
|
||||
return yargs
|
||||
.option('projectName', {
|
||||
alias: 'p',
|
||||
description: 'Name of the folder to scaffold a project to',
|
||||
type: 'string',
|
||||
demandOption: false,
|
||||
})
|
||||
.option('template', {
|
||||
alias: 't',
|
||||
description: 'Frontend framework to use for CEF',
|
||||
type: 'string',
|
||||
demandOption: false,
|
||||
})
|
||||
}
|
||||
|
||||
async function handler(args: ArgumentsCamelCase) {
|
||||
let folder = (args.projectName as string) ?? args.p
|
||||
let framework = (args.template as string) ?? args.t
|
||||
|
||||
if (!folder) {
|
||||
folder = await input({
|
||||
message: c.gray('Enter project name:'),
|
||||
default: 'rage-fw',
|
||||
})
|
||||
} else {
|
||||
console.log(c.gray('Project name:'), folder)
|
||||
}
|
||||
|
||||
if (!framework) {
|
||||
framework = await select({
|
||||
message: c.gray('Select frontend:'),
|
||||
default: 'react',
|
||||
loop: true,
|
||||
choices: [
|
||||
{
|
||||
name: 'React + TypeScript (Vite)',
|
||||
value: 'react',
|
||||
description: 'React + TypeScript (Vite) as a frontend',
|
||||
},
|
||||
// {
|
||||
// name: 'vue',
|
||||
// value: 'vue',
|
||||
// description: 'npm is the most popular package manager',
|
||||
// },
|
||||
],
|
||||
})
|
||||
} else {
|
||||
console.log(c.gray('Frontend:'), framework)
|
||||
}
|
||||
|
||||
console.log(
|
||||
c.gray('\nScaffolding template project into'),
|
||||
@ -56,11 +82,11 @@ async function handler() {
|
||||
)
|
||||
}
|
||||
|
||||
// name and description for our command module
|
||||
const init: CommandModule = {
|
||||
command: 'create [template]',
|
||||
command: 'create [folderName] [template]',
|
||||
aliases: 'c',
|
||||
describe: 'Scaffold a template project using RageFW',
|
||||
builder,
|
||||
handler,
|
||||
}
|
||||
|
||||
|
@ -6,5 +6,6 @@ yargs
|
||||
.usage('<cmd> [args]')
|
||||
// .scriptName('rage-fw')
|
||||
// .usage('$0 <cmd> [args]')
|
||||
// @ts-ignore
|
||||
.command(create)
|
||||
.help().argv
|
||||
|
Loading…
Reference in New Issue
Block a user