- 🚀 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.json
target 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 git@github.com: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
.git
folder - 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 install
to install all dependencies - (Optional) Run
npm outdated
to see if any dependencies have major updates. - (Optional) Run
npm update
to get those dependencies up to date with minor updates. - Update the
package.json
with your project's details- Set the
name
field. 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
description
field. - Set the
repository
field to your remote git repo's URL. - Set the
homepage
field (your remote git repo's URL works fine for this). - Add any
keywords
strings. If you publish to npm, these will be used by searches. - Remove the
private
field if you want to publish to npm. - If you do not want to publish to npm, remove
&& npm publish
from thescripts.postversion
script.
- Set the
- Check the
.gitignore
and 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.json
file to see if you want to change anything. Pay particular attention to thepaths
section! - 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
build
folder, 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/lib
andsrc/types
. - If you intend to use the
fs-extra
module for anything in your non-test code, move it from thedevDependencies
to thedependencies
section 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.ts
tosrc/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-command
available to users who install your npm package, add thebin
field to yourpackage.json
, like so:{ //... other root package.json options "bin": { "your-cli-command": "build/cli/your-main-cli-name.js" } }
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/test
as 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.json
to 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 patch
to bump the patch version, indicated a bugfixnpm version minor
to bump the minor version, indicating a new feature (backwards-compatible)npm version major
to 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.json
file. - Update
CHANGELOG.md
to reflect the new version. git add
all file changes.- Commit changes and create a version tag.
- Push changes to remote
- Publish package to
npm
.