@bksp/style-guide v0.2.0
B4CKSP4CE Code Style Guide
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-guideESLint
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-eslintThere 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
This style guide includes a TypeScript configuration snippet, providing basic constraints for TypeScript projects.
Notice that it isn't a full tsconfig.json file, but rather a set of rules to be extended in your project's tsconfig.json.
For now, this configuration is matching the @tsconfig/strictest package.
However, we might adjust it in the future to better fit our needs.
To use the shared TypeScript config, you need to extend it in your tsconfig.json file:
{
  "extends": "@bksp/style-guide/typescript"
}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-msgCredits
This project is heavily inspired by The Vercel Style Guide. Thanks, Vercel, for sharing this amazing piece of work!