- 🚀 Start coding immediately, without worrying about configuration
- 📰 Publish your package to NPM with only a few tweaks
- 🧹 Use a tidy file structure that is already set up for dev
- 🧪 Test suite ready to fill out
- 💻 Deliver a Command Line Interface version of your project
- ✨ Auto-format your code with Prettier
- 🔬 Find issues with ESLint
- ⚡ Includes Visual Studio Code extension recommendations and default settings, for maximum productivity out of the box
Getting a Typescript project running is a pain, since there is a lot of environment and configuration setup before you can get started. If you want to be able to publish your Typescript project to npm there is even more configuration to ensure that you are only (and definitely) pushing the files that are strictly needed. Finally, setting up testing can be confusing, especially since test code also needs to be compiled but should not be included with your published npm package.
This starter kit aims to alleviate all the annoyance of setting up a modern Typescript project for Node packages.
- This template is for Node, not Browser, projects.
- To support Node versions <14 you may need to change the
tsconfig.jsontarget settings.
- Node.js v13.2+ (v14+ highly recommended)
This project is set up as a GitHub template.
- Click the "Use this Template" button on the project homepage to create your own remote repo with everything here. Follow the prompts.
- On your local machine, use GitHub Desktop to clone the repo, or
navigate to the parent folder where you want to keep your
local repo copy and run
git clone your-remote-url.
- Create a new remote repo on your host (e.g. GitHub, BitBucket, GitLab, etc.)
- Go to the local parent folder into which you want to put your new Typescript project (via your file explorer or a terminal)
- Clone this repo locally:
git clone --branch develop [email protected]:bscotch/typescript-template.git - Rename the folder containing this repo (
typescript-template) to your project's name - Go to your new local repo (via a Git GUI or a terminal (with
cd your-new-name)) - (Optional) If you don't want the git history from this template to be included in your project's history:
- Delete the
.gitfolder - Run
git init(or use a Git GUI to initialize the repo) - Change the remote to your own remote repository:
git remote set-url origin your-remote-url(or, if you initialized a new repo, add your remote withgit remote add origin your-remote-url)
- Run
npm installto install all dependencies - (Optional) Run
npm outdatedto see if any dependencies have major updates. - (Optional) Run
npm updateto get those dependencies up to date with minor updates. - Update the
package.jsonwith your project's details- Set the
namefield. If you are going to publish to npm, this will be the name of your package. Must be a URL-friendly name. Best practice is to use kebab-case (all lower-case, alphanumeric and dashes). - Set the
descriptionfield. - Set the
repositoryfield to your remote git repo's URL. - Set the
homepagefield (your remote git repo's URL works fine for this). - Add any
keywordsstrings. If you publish to npm, these will be used by searches. - Remove the
privatefield if you want to publish to npm. - If you do not want to publish to npm, remove
&& npm publishfrom thescripts.postversionscript.
- Set the
- Check the
.gitignoreand add any filetypes or folders you want to keep out of your repo. - Remove any stuff from the template that you don't care about. (You can do this at any time.)
- Open up the
./tsconfig.jsonfile to see if you want to change anything. Pay particular attention to thepathssection! - Commit all your changes:
git add -A; git commit - Push your commit:
git push
- Your entrypoint is
./src/index.ts, so start there! - Your compiled code will appear in a git-ignored
buildfolder, with entrypointbuild/index.js. - To compile, run
npm run build - To auto-recompile while you code, run
npm run build-live - Sample folders and files for types and your code library are placed in
src/libandsrc/types. - If you intend to use the
fs-extramodule for anything in your non-test code, move it from thedevDependenciesto thedependenciessection of yourpackage.json.
This template project comes with the commander module,
which is great for rapidly building command line interfaces
(uninstall it with npm uninstall commander if you don't need to make a CLI).
To create a CLI that will become available when someone installs your npm package:
- Rename
src/cli/cli.tstosrc/cli/your-main-cli-name.ts. This is the entrypoint for your CLI. - Name any subcommand files to
src/cli/your-main-cli-name-subcommand.ts. Update the CLI entrypoint to use the same subcommand names. Subcommand scripts must start with the same name as your main CLI script, and must end with an exact command name listed by its parent script (one of thecli.command()values). - Modify the CLI templates to do whatever it's all supposed to do.
- To make
your-cli-commandavailable to users who install your npm package, add thebinfield to yourpackage.json, like so:
Test your CLI locally by running node build/cli/your-main-cli-name.js -h.
If you publish your project as an npm module, users who install it will be able
to run npx your-cli-command in their terminals, or simply your-cli-command
if they've done a global install of your module (with npm install --global your-module-name).
- Add tests to
./src/testas you go. - Place any reference data for tests into
./samples - Run tests from the terminal with
npm test(make sure your code is compiled first). - Run tests from VSCode (click the debugger on the sidebar) to use breakpoints and allow inspection:
- Use the "Tests" option to run against your compiled code.
- Console logs will appear in the Debug Console, where you can also step through your code if you set breakpoints.
- Edit
./.vscode/launch.jsonto add or change the tests.
When you are ready to increment the version of your project, which by default
is coupled to publishing to npm and merging into your main branch
(edit this behavior in the scripts section of the package.json),
use the npm version commands. For example:
npm version patchto bump the patch version, indicated a bugfixnpm version minorto bump the minor version, indicating a new feature (backwards-compatible)npm version majorto bump the major version, indicating substantial and/or breaking changes
The preversion, version, and postversion scripts in the package.json file dictate what happens
when you use an npm version command. By default, the sequence of things that happen are:
- Source is compiled into plain JavaScript.
- Tests are run against the compiled JavaScript. If any fail, the process aborts.
- Increment the version number in the
package.jsonfile. - Update
CHANGELOG.mdto reflect the new version. git addall file changes.- Commit changes and create a version tag.
- Push changes to remote
- Publish package to
npm.
{ //... other root package.json options "bin": { "your-cli-command": "build/cli/your-main-cli-name.js" } }