docs/FONTS.md
First, you will have to make a personal copy of the Monkeytype repository, also known as "forking". Go to the Monkeytype repo and then click the "fork" button.
Once you have forked the repository you can now add your font. Place the font file in ./frontend/static/webfonts e.g. My-Font.woff2.
[!NOTE] Your font needs to be in the
.woff2format. Your filename cannot include spaces or start with a number.
Open ./packages/schemas/src/fonts.ts and add the new font at the end of the KnownFontNameSchema list like this:
const KnownFontNameSchema = z.enum(
[
"Roboto_Mono",
"Noto_Naskh_Arabic",
...
"My_Font",
Call it whatever you want but make sure you replace spaces with underscores and the font does not start with a number.
Then, go to ./frontend/src/ts/constants/fonts.ts and add the following code to the end of the Fonts object near to the very end of the file:
export const Fonts: Record<KnownFontName, FontConfig> = {
...
My_Font: {
fileName: "My-Font.woff2",
}
Once you have created your language, you now need to create a pull request to the main Monkeytype repository. Go to the branch where you created your languages on GitHub. Then make sure your branch is up to date. Once it is up to date, click "contribute".
Update branch:
Create a pull request:
Make sure your language follows the Language guidelines.