Skip to content
/ template-discordbot Public template

An esm nodejs template for discord bots using discord.js

Notifications You must be signed in to change notification settings

mkvlrn/template-discordbot

Repository files navigation

template-discordbot

A sane, opinionated template for discord bots written in typescript using the discord.js library.

Uses:

  • biome for linting and formatting
  • tsx for running typescript code without transpiling
  • vitest for tests
  • commitlint for linting commit messages
  • husky for git hooks

prerequisites

  • filled variables in .env file (see .env.example)
  • a notion of what a discord bot is and how discord.js works
  • a server to test the bot on (that's where you get the server id for the env variable)

running

yarn dev

Runs the project in watch mode, automatically restarting on changes. Uses tsx to run the typescript code without transpiling to ./build.

yarn build

Builds/transpiles the code to ./build.

yarn start

Runs the built project.

yarn register <serverId>, yarn register global

Registers all bot commands in ./commands to the specified discord server or globally. Read more here.

yarn test, yarn test:e2e

Runs tests with vitest.

yarn tidy

Runs biome in fix mode (only safe fixes) to lint and format the project. Not only ./src, but also all "loose" config files around root (js, ts, json, jsonc) or other directories.

yarn typecheck

Runs type checking using tsc and the tsconfig.json file, which is not the one used to build the project.

that tsconfig.json seems very strict and opinionated

Yup.

vscode

You might want to install the recommended extensions in vscode. Search for @recommended in the extensions tab, they'll show up as "workspace recommendations".

If you have been using eslint and prettier and their extensions, you might want to disable eslint entirely and keep prettier as the formatter only for certain types of files.

I suggesting using the settings in .vscode/settings-example.json, that should be pasted into your own .vscode/settings.json. I'm not commiting the .vscode/settings.json proper because it shouldn't be in VCS as it contains your personal settings.

About

An esm nodejs template for discord bots using discord.js

Topics

Resources

Stars

Watchers

Forks