|
1 | 1 | import fs from 'fs'; |
2 | 2 | import path from 'path'; |
3 | 3 | import commander from 'commander'; |
4 | | -import copyFolder from '../utils/copyFolder'; |
| 4 | +import inquirer from 'inquirer'; |
5 | 5 |
|
| 6 | +import { replaceMaskFile } from '../utils/replaceMask'; |
| 7 | +import copyFolder from '../utils/copyFolder'; |
6 | 8 | import createPackageJson from '../stages/CreatePackageJson'; |
7 | 9 | import installDependencies from '../stages/InstallDependencies'; |
8 | 10 | import initializeGit from '../stages/InitializeGit'; |
9 | 11 | import Log from '../Log'; |
10 | 12 |
|
11 | | -const createProject = (name: string) => { |
12 | | - if (name) { |
13 | | - Log.Instance.infoHeap(`Creating the project`); |
| 13 | +const createProject = ( |
| 14 | + projectName: string, |
| 15 | + packageManager: 'yarn' | 'npm', |
| 16 | + httpFramework: 'koa' | 'express' | 'hapi' |
| 17 | +) => { |
| 18 | + Log.Instance.infoHeap(`Creating the project`); |
14 | 19 |
|
15 | | - const source = path.join(__dirname, '/../../templates/project'); |
16 | | - const target = path.join(process.cwd(), name); |
| 20 | + const source = path.join(__dirname, '/../../templates/project'); |
| 21 | + const target = path.join(process.cwd(), projectName); |
17 | 22 |
|
18 | | - try { |
19 | | - Log.Instance.infoHeap(`Copying files`); |
20 | | - fs.mkdirSync(name); |
| 23 | + try { |
| 24 | + Log.Instance.infoHeap(`Copying files`); |
| 25 | + fs.mkdirSync(projectName); |
21 | 26 |
|
22 | | - copyFolder(source, target); |
23 | | - fs.renameSync( |
24 | | - path.join(target, 'gitignore'), |
25 | | - path.join(target, '.gitignore') |
26 | | - ); |
| 27 | + copyFolder(source, target); |
| 28 | + fs.renameSync( |
| 29 | + path.join(target, 'gitignore'), |
| 30 | + path.join(target, '.gitignore') |
| 31 | + ); |
| 32 | + replaceMaskFile(path.join(target, 'config/app.ts'), { |
| 33 | + projectName, |
| 34 | + httpFramework |
| 35 | + }); |
27 | 36 |
|
28 | | - createPackageJson(target, name); |
29 | | - installDependencies(target); |
30 | | - initializeGit(name); |
| 37 | + createPackageJson(target, projectName, httpFramework); |
| 38 | + installDependencies(target, packageManager); |
| 39 | + initializeGit(projectName); |
31 | 40 |
|
32 | | - Log.Instance.successHeap(`The ${name} project was created.`); |
33 | | - Log.Instance.info(`Path: ${target}\n\n`); |
34 | | - } catch (err) { |
35 | | - Log.Instance.exception(err); |
36 | | - } |
37 | | - } else { |
38 | | - Log.Instance.errorHeap(`Specify the name project.`); |
39 | | - Log.Instance.info( |
40 | | - `For example: recife-cli project my-project-name\nRun --help for more information` |
41 | | - ); |
| 41 | + Log.Instance.successHeap(`The ${projectName} project was created.`); |
| 42 | + Log.Instance.info(`Path: ${target}\n\n`); |
| 43 | + } catch (err) { |
| 44 | + Log.Instance.exception(err); |
42 | 45 | } |
43 | 46 | }; |
44 | 47 |
|
| 48 | +const createProjectWithOptions = () => { |
| 49 | + inquirer |
| 50 | + .prompt([ |
| 51 | + { |
| 52 | + name: 'projectName', |
| 53 | + message: 'Project Name:', |
| 54 | + type: 'string', |
| 55 | + default: 'my-project' |
| 56 | + }, |
| 57 | + { |
| 58 | + name: 'packageManager', |
| 59 | + message: 'Package Manager:', |
| 60 | + type: 'list', |
| 61 | + default: 'npm', |
| 62 | + choices: ['npm', 'yarn'] |
| 63 | + }, |
| 64 | + { |
| 65 | + name: 'httpFramework', |
| 66 | + message: 'Http Framework:', |
| 67 | + type: 'list', |
| 68 | + default: 'koa', |
| 69 | + choices: ['koa', 'express', 'hapi'] |
| 70 | + } |
| 71 | + ]) |
| 72 | + .then((answers: any) => { |
| 73 | + Log.Instance.jump(); |
| 74 | + createProject( |
| 75 | + answers.projectName, |
| 76 | + answers.packageManager, |
| 77 | + answers.httpFramework |
| 78 | + ); |
| 79 | + }); |
| 80 | +}; |
| 81 | + |
45 | 82 | commander |
46 | 83 | .name(`recife-cli project`) |
47 | | - .arguments('<project-name>') |
48 | | - .action(name => createProject(name)) |
| 84 | + .arguments('[project-name]') |
| 85 | + .option('-p, --package-manager <packageManager>', 'Package Manager', 'npm') |
| 86 | + .option('-h, --http-framework <httpFramework>', 'Http Framework', 'koa') |
| 87 | + .action((name, cmd) => { |
| 88 | + if (name) { |
| 89 | + createProject(name, cmd.packageManager, cmd.httpFramework); |
| 90 | + } else { |
| 91 | + createProjectWithOptions(); |
| 92 | + } |
| 93 | + }) |
49 | 94 | .allowUnknownOption(false) |
50 | 95 | .parse(process.argv); |
0 commit comments