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
- 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)
Runs the project in watch mode, automatically restarting on changes. Uses tsx to run the typescript code without transpiling to ./build
.
Builds/transpiles the code to ./build
.
Runs the built project.
Registers all bot commands in ./commands
to the specified discord server or globally. Read more here.
Runs tests with vitest.
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.
Runs type checking using tsc and the tsconfig.json
file, which is not the one used to build the project.
Yup.
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.