Developer Ready: A versatile template designed to jumpstart CLI development in TypeScript - Engineered to seamlessly integrate with various CLI projects, ensuring smooth compatibility with a pre-configured environment.
Instant Value - All basic tools included and configured:
- π Typescript >= 5.3
- π§ Bun.js >= 1.0.26
- π§ Use Bun as package manager
- π ESM
- π§ͺ Biome for code formatting and linting
- β Jest or Bun test for fast unit testing and code coverage
- π Type definitions for Bun.js and Jest
- βοΈ EditorConfig for consistent coding style
- π¦ NPM scripts for common operations
- π οΈ Example configuration for GitHub Actions
- π Simple example of TypeScript code and unit test
- π Run tasks with Grunt (example for backup)
- π Build faster
- π₯οΈ Ungit for version control (git) with a GUI
- π§ͺ A lightweight private npm proxy registry with Verdaccio, useful for testing your CLI
- π³ Inquirer.js - A collection of common interactive command line user interfaces
- π³ Execa - A process execution library that supports synchronous and asynchronous execution of child processes
- π³ Figlet - A program that generates text banners, in a variety of typefaces, composed of letters made up of conglomerations of smaller ASCII characters
- π³ Node-emoji - A library that provides a simple way to use emojis in your CLI
- π³ Ora - A terminal spinner library that allows you to add a loading spinner to your CLI
- π³ Chalk - A library for styling terminal strings with colors and text styles
To use this template, use the following commands:
bun create github.com/RajaRakoto/cli-boilerplate <project-name>
cd <project-name>
bun run pkg-upgrade # to upgrade outdated dependencies in interactive mode
NOTE 1: I employ the
MIT license
for this starter kit, which includes my name and GitHub profile. Please remember to adjust or remove it if deemed unnecessary.
NOTE 2: In order to help you better understand the structure of this boilerplate, there is a
README.md
file in each subdirectory of src.
NOTE 3: For certain configurations in the
package.json
file, you need to modify them to tailor them to your project (e.g: name, description, author, keywords, main, repository, ...).
Start
- π
start
- Run your application with bun. - π
start:smol
- Run your application with bun and a flag which configures the JavaScriptCore heap size to be smaller and grow slower. - π
start:bin
- Run your standalone binary app.
Clean
- π
clean
- Remove coverage data, prod, build.
Development
- π
dev
- Launch your application in development mode with bun. - π
dev:watch
- Interactive watch mode to automatically transpile source files with bun in development. - π
dev:hot
- Hot reloading of source files with bun in development. - π
dev:smol:watch
- Interactive watch mode to automatically transpile source files with bun in development, while using --smol flag. - π
dev:smol:hot
- Hot reloading source files with bun in development, while using --smol flag.
Build
- π
build
- Transpile and bundle source files with bun. - π
build:watch
- Interactive watch mode to automatically transpile source files with bun. - π
build:bin
- bun's bundler implements a --compile flag for generating a standalone binary from a TypeScript or JavaScript file, use this in your production environment to ensure optimal execution of your app.
Testing
- π
test
- Run bun test. - π
test:watch
- Interactive watch mode to automatically re-run tests with bun.
Linting and Formatting
- π
biome:start
- Starts the Biome daemon server. You can specify a custom configuration file path using the--config-path
option. - π
biome:stop
- Stops the Biome daemon server. - π
biome:fix
- Runs a source code check and applies automatic fixes (linter & formatter) according to the defined rules. - π
biome:unsafe
- Works likebiome:fix
, but may apply more invasive or risky changes.
Backup and Dependency Management
- π
backup
- Backup files with Grunt. - π
pkg-check
- Check useless dependencies with depcheck. - π
pkg-upgrade
- Upgrade outdated dependencies (interactive mode) with npm-check-updates.
Versioning
- π
versioning
- Start ungit server.
NPM Commands
- π
npm-version:major
- Increments the major version number of your project using npm. - π
npm-version:minor
- Increments the minor version number of your project using npm. - π
npm-version:patch
- Increments the version patch number of your project using npm. - π
npm-login
- Login to a registry user account. - π
npm-publish
- Publish your npm package with public access. - π
npm-unpublish
- Forcefully unpublish the cli package from npm. - π
npm-reset:registry
- Delete the custom npm registry. - π
npm-check:registry
- Get the currently configured registry for npm. - π
npm-proxy-set:registry
- Set the npm registry to use a local proxy. - π
npm-proxy:start
- Start a Verdaccio server with a local npm proxy. - π
npm-proxy:publish
- Publish your npm package via the local proxy. - π
npm-proxy:unpublish
- Forcefully unpublish the cli package from the npm registry via the local proxy. - π
npm-proxy:republish
- Republish your npm package by first unpublishing it and then publishing it again via the local proxy.
NVM
- π
nvm
- Manage multiple node.js versions. Easily switch between node versions per project to ensure compatibility.
When using the build.js file in this boilerplate, it's important to note the significance of the target option. By default, if the target option is not specified in the build.js file, it will be set to browser
. However, for projects utilizing the bun.js
runtime environment, it's imperative to explicitly set the target to bun
. This guarantees compatibility with the bun
shell environment and prevents unexpected behavior. Furthermore, it's noteworthy that the target
supports three possible values: browser
, bun
, and node
, providing flexibility in defining the build target according to specific project requirements.
You can also check out my other starter projects:
- π node-boilerplate
- π react-boilerplate
- π next-boilerplate
- π qwik-boilerplate
- π vscode-boilerplate
- π bun-boilerplate