Skip to content

Latest commit

 

History

History
124 lines (88 loc) · 9.23 KB

typelaunch.md

File metadata and controls

124 lines (88 loc) · 9.23 KB

TypeLaunch

GitHub GitHub all releases GitHub issues GitHub commit activity GitHub last commit Snyk Vulnerabilities for GitHub Repo

TypeLaunch is an opinionated, public template repository made to easily bootstrap a TypeScript library with the latest features and best practices.

Pipeline

Setup

To use this template

There are multiple edits that should be made to personalize TypeLaunch. Below is a checklist in order of importance.

  1. Add a name beyond "typelaunch-starter" in package.json and vite.config.ts
  2. Add a SCOPED_REPO_TOKEN and NPM_TOKEN to your repo's secrets. This allows GitHub Actions to manage deploying to npm. See this issue for more information.
  3. Replace the placeholder name "John Appleseed" with the project owner's name in the LICENSE
  4. Replace all instances of the placeholder email "[email protected]" with the project owner's email address in the CODE_OF_CONDUCT.md
  5. Add or customize these fields in package.json:
    1. author
    2. email
    3. description
    4. repository: provide a link to the GitHub repo this project resides in
    5. homepage: provide a link to one of these resources
      1. Front-facing webpage
      2. Documentation
      3. GitHub repo
    6. bugs.url: provide a link to your bug tracker
    7. keywords

Cycle

Opening

When opening the project, create a new terminal window and run pnpm run dev. This will set up Vitest every time the project is saved. Best practice is to stop this terminal when closing the project, though that's not entirely necessary.

CI/CD

VSCode

When a commit is ready to be made, head to the Version Control pane and stage the files you'd like to commit. Next, look for the circle above the commit field labeled "Conventional Commits", or hit Ctrl/Cmd + Shift + P to open the Command Palette and find it that way. In the Command Palette, type "Conventional Commits" and find the command with that title.

The Conventional Commits extension will walk you through the steps to making a conventional commit.

GitHub

When enough commits have been made, make a changeset and push your changes to GitHub! There are two types of commit sets: release, and non-release.

The commit set is a release set if the commit set changes your project's features (i.e. if there are any feat commits). Any other commit set will not require a release and can be considered a non-release set.

To push a release set, run pnpm run change and note the features you've added, changed, or removed. Commit this and push to a dev branch. To publish a non-release set, run pnpm run change:empty and commit and push to the main branch.

Releasing

When you're ready to release, take a look at the Pull Request to main that the Changeset GitHub Action has created under your name. Follow the instructions there and only merge the Pull Request when you're comfortable with it. When you do merge, GitHub Actions and Changset will take care of publishing to npm and tagging your release on GitHub.

Conventions

This project adheres to the following conventions to keep code writing and reviewing easy.

  1. Conventional Commits
  2. Semantic Versioning
  3. ESLint recommended rules
  4. Prettier recommended rules

Dependencies

This project makes use of some dev dependencies that enforce following the above conventions and overall improve code quality.

  • Essentials - TypeScript, a type-safe superset of JavaScript
  • Testing and Coverage - Vitest, a fast, batteries-included test runner
  • Linting and Formatting
    • ESLint for potential bugs and convention adherence
    • Prettier for styling
  • Version Control and CI/CD

Recommendations

  • TypeScript is provided for type-safety and is intended to be used instead of JavaScript. The tsconfig included uses strict mode, so the TypeScript compiler will complain about a lot of things. Remember, TypeScript errors are your friend.
  • Usage of docstrings is highly encouraged, as it provides an easy way to produce documentation. The docstrings you make allow IDE's like VSCode (my personal favorite) to provide inline documentation and tab completion directly in the editor!
  • Use Vitest for test-driven or behavior-driven development. Before working on the project, run pnpm run dev to get Vitest going. See the Commands section for more details.

Opinions and Philosophy

TypeLaunch is an opinionated template. The most important tenets of TypeLaunch are:

  • Clutter bad, ❌ intuitive structure good ✅
  • Rigidity bad, ❌ easy customization good ✅
  • Looseness bad, ❌ constructive strictness good ✅
  • Manual bad, ❌ automatic help good ✅

The more granular opinions are described below:

  • ESLint and Prettier are pre-configured in the project's package file. This is where most of the opinions are.
    • Prettier has no config key because all presets/recommendations are followed.
    • All recommended ESLint presets are followed, with the exception of two additional rules. They are set to warn and not throw an exception because they are slightly pedantic.
      • spaced-comment is in always mode, which will "enforce consistent spacing after the // or /* in a comment". See here for details.
      • yoda is in never mode, which will disallow "Yoda conditions" where a literal is compared to a variable and not the other way around. See here for details.
  • I've worked on projects where the root directory is a mess of config files with no way to hide them because they all had to be at the root. Therefore, I've tried to hide as much of the config in package.json as I can. Most of these config keys can be moved to their own files if necessary by making a <package>rc.* file at the root. Read the package's documentation before doing so to see if it is possible, but if so, feel free to.
  • In the same spirit, the code of conduct is in the .github folder, but can be moved to the project root.
  • Part of the reason I made this template is to have full control over what tools I used and how I used them. I brought this design philosophy to TypeLaunch as much as I could; if a package is getting in your way, you just need to uninstall it; the only one that needs some extra config is changesets because that's integrated into the CI build. Otherwise, it's as simple as pnpm uninstall <package>.
  • TypeLaunch is also dependency-free for a reason: the thing shouldn't get in the way of what your application needs and should only help you if you develop it. Usage of TypeLaunch not contributing to build sizes is also a nice plus.
  • Errors are your friend. No seriously. I've configured TypeLaunch to berate the developer with errors, exceptions, and test failures. Errors are also the lifeblood of test-driven development, a practice I'm getting better at following. Adding these errors is meant to make sure the code, docs, and tests are in tip-top shape.

Commands

Utilize these commands in your development pipeline by running pnpm run <command>. For convenience, a table for these commands is included here:

Command Description
dev Run Vitest tests in watch mode
build Build the project
lint Lint the project with TSC, ESLint, and Prettier
test Run Vitest tests once
test:watch Run Vitest tests in watch mode
cov Run Vitest tests and provide a coverage report
cov:watch Run Vitest tests in watch mode and provide a coverage report
cov:detail Run Vitest tests and open a coverage report in the browser
change Create a changeset
change:empty Create a special changeset with no changes noted
review Review your changeset changes
release Build the project and create or update the changelog