mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-09 08:03:30 +01:00
feat: Add no-install option (#9604)
* chore: no install option + fix type * chore: apply suggestions Co-authored-by: Jiralite <33201955+Jiralite@users.noreply.github.com> --------- Co-authored-by: Jaw0r3k <jaw0r3k.git@gmail.com> Co-authored-by: Jiralite <33201955+Jiralite@users.noreply.github.com>
This commit is contained in:
@@ -40,8 +40,9 @@ program
|
||||
})
|
||||
.option('--typescript', 'Whether to use the TypeScript template.')
|
||||
.option('--javascript', 'Whether to use the JavaScript template.')
|
||||
.option('--no-install', 'Whether to not automatically install the packages.')
|
||||
.addOption(
|
||||
new Option('--packageManager <packageManager>', 'The package manager to use.')
|
||||
new Option('--package-manager <packageManager>', 'The package manager to use.')
|
||||
.choices(PACKAGE_MANAGERS)
|
||||
.default(resolvePackageManager()),
|
||||
)
|
||||
@@ -49,7 +50,7 @@ program
|
||||
.parse();
|
||||
|
||||
// eslint-disable-next-line prefer-const
|
||||
let { typescript, javascript, packageManager } = program.opts();
|
||||
let { typescript, javascript, packageManager, install: installPackages } = program.opts();
|
||||
|
||||
if (!projectDirectory) {
|
||||
projectDirectory = (
|
||||
@@ -100,4 +101,4 @@ if (!deno && typescript === undefined && javascript === undefined) {
|
||||
typescript = useTypescript;
|
||||
}
|
||||
|
||||
await createDiscordBot({ typescript, directory: projectDirectory, packageManager });
|
||||
await createDiscordBot({ typescript, directory: projectDirectory, packageManager, installPackages });
|
||||
|
||||
25
packages/create-discord-bot/src/create-discord-bot.ts
Executable file → Normal file
25
packages/create-discord-bot/src/create-discord-bot.ts
Executable file → Normal file
@@ -11,11 +11,12 @@ import { GUIDE_URL } from './util/constants.js';
|
||||
|
||||
interface Options {
|
||||
directory: string;
|
||||
installPackages: boolean;
|
||||
packageManager: PackageManager;
|
||||
typescript?: boolean;
|
||||
}
|
||||
|
||||
export async function createDiscordBot({ directory, typescript, packageManager }: Options) {
|
||||
export async function createDiscordBot({ directory, installPackages, typescript, packageManager }: Options) {
|
||||
const root = path.resolve(directory);
|
||||
const directoryName = path.basename(root);
|
||||
|
||||
@@ -88,16 +89,18 @@ export async function createDiscordBot({ directory, typescript, packageManager }
|
||||
});
|
||||
await writeFile('./package.json', newPackageJSON);
|
||||
|
||||
try {
|
||||
install(packageManager);
|
||||
} catch (error) {
|
||||
console.log();
|
||||
const err = error as ExecException;
|
||||
if (err.signal === 'SIGINT') {
|
||||
console.log(red('Installation aborted.'));
|
||||
} else {
|
||||
console.error(red('Installation failed.'));
|
||||
process.exit(1);
|
||||
if (installPackages) {
|
||||
try {
|
||||
install(packageManager);
|
||||
} catch (error) {
|
||||
console.log();
|
||||
const err = error as ExecException;
|
||||
if (err.signal === 'SIGINT') {
|
||||
console.log(red('Installation aborted.'));
|
||||
} else {
|
||||
console.error(red('Installation failed.'));
|
||||
process.exit(1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user