simple-git-hooks
simple-git-hooks is a widely adopted Git tool that helps you manage Git hooks easily.
Other options
husky is a more widely adopted tool, but it modifies the Git hooks directory, which you may not like. You might consider using it, but you'll need to configure it yourself.
Installation
You have to install simple-git-hooks first. Currently simple-git-hooks v2 is supported.
npm install simple-git-hooks is-ci esbuild-register -D
yarn add simple-git-hooks is-ci esbuild-register -D
pnpm install simple-git-hooks is-ci esbuild-register -D
Configuration
Create simple-git-hooks.cjs
in your project root:
// simple-git-hooks.cjs
require("esbuild-register");
const { simpleGitHooks } = require("@modyqyw/fabric/simple-git-hooks");
module.exports = simpleGitHooks();
Update package.json
and add prepare
script.
{
"scripts": {
"prepare": "is-ci || simple-git-hooks"
}
}
Customization
Parameters
Passing parameters to the exported simpleGitHooks
method can customize, and the simpleGitHooks
method takes two parameters.
The first parameter is used for basic customization; you can pass no or empty objects to indicate the use of default values. To explicitly enable or disable a plugin, you need to explicitly set the boolean value in the passed object.
The following is the default configuration:
- commitlint - Use commitlint to lint commit messages. Enabled by default if you have commitlint installed.
- lintStaged - Use lint-staged to execute commands against staged git files. Enabled by default if you have lint-staged installed.
// simple-git-hooks.cjs
require("esbuild-register");
const { hasCommitlint, hasLintStaged } = require("@modyqyw/fabric");
const { simpleGitHooks } = require("@modyqyw/fabric/simple-git-hooks");
module.exports = simpleGitHooks({
// Lint commit messages with commitlint.
// Enabled by default if you have commitlint installed.
commitlint: hasCommitlint,
// Execute commands against staged git files with lint-staged.
// Enabled by default if you have lint-staged installed.
lintStaged: hasLintStaged,
});
The second parameter is used for further customization, you can pass an object to override the generated configuration.
// simple-git-hooks.cjs
require("esbuild-register");
const { simpleGitHooks } = require("@modyqyw/fabric");
module.exports = simpleGitHooks(
{},
{
// configs that require customization
},
);