/style-guide

💅 Style guide for TypeScript & JavaScript projects

Primary LanguageJavaScriptMozilla Public License 2.0MPL-2.0

B4CKSP4CE Code Style Guide

MPL-2.0 License NPM Version neostandard javascript style

Introduction

This repository is the home of B4CKSP4CE's style guide, which includes configs for popular linting and styling tools.

The following configs are available, and are designed to be used together.

Install the package using your package manager of choice:

# Using pnpm
pnpm install --save-dev @bksp/style-guide

ESLint

Note: ESLint is a peer-dependency of this package, and should be installed at the root of your project.

# Install ESLint and TypeScript ESLint parser required for the shared config
pnpm install --save-dev eslint typescript-eslint

There are two ESLint configurations available:

  • @bksp/style-guide/eslint/node - for generic Node.js projects
  • @bksp/style-guide/eslint/next - for Next.js projects

Re-export the desired configuration in your project's eslint.config.mjs file:

// eslint.config.mjs
import next from '@bksp/style-guide/eslint/next'
export default next;

You can extend this configuration to add project-specific rules. Read more about it in Configuring ESLint documentation.

TypeScript

Please use @tsconfig/strictest directly in your projects:

{
  "extends": "@tsconfig/strictest"
}

Commitlint

Commitlint is a linting tool for commit messages. We use it to enforce a consistent use of Conventional Commits specification.

In order to use the shared Commitlint config, you need to install the following packages:

# Install commitlint and husky for git hooks
pnpm install --save-dev @commitlint/cli husky

# Link the shared config
echo "export default { extends: ['@bksp/style-guide/commitlint'] }" > .commitlintrc.mjs

# Initialize husky
pnpm husky init

# Add a commit-msg hook
echo "pnpm dlx commitlint --edit \$1" > .husky/commit-msg

Credits

This project is heavily inspired by The Vercel Style Guide. Thanks, Vercel, for sharing this amazing piece of work!