This project is a plugin for CaptainHook to check JavaScript files
using ESLint in a git pre-commit hook. By default all *.js
and *.mjs
files are checked, and
the commit is blocked when one or more errors are found. Warnings produced by ESLint are ignored.
Install as a development dependency using composer:
$ composer require --dev moxio/captainhook-eslint
Add ESLint validation as a pre-commit
to your captainhook.json
configuration file:
{
"pre-commit": {
"enabled": true,
"actions": [
{
"action": "\\Moxio\\CaptainHook\\ESLint\\ESLintAction"
}
]
}
}
The action expects ESLint to be installed as a local NPM package (i.e. available at
node_modules/.bin/eslint
). It should be configured
in a way that automatically finds the appropriate configuration, e.g. as an .eslintrc.*
file or with the eslintConfig
field in package.json
.
If you want to perform ESLint validation only when ESLint is installed (i.e. available at node_modules/.bin/eslint
),
you can add a corresponding condition to the action:
{
"pre-commit": {
"enabled": true,
"actions": [
{
"action": "\\Moxio\\CaptainHook\\ESLint\\ESLintAction",
"conditions": [
{
"exec": "\\Moxio\\CaptainHook\\ESLint\\Condition\\ESLintInstalled"
}
]
}
]
}
}
This may be useful in scenarios where you have a shared CaptainHook configuration file that is included both in projects that use ESLint and projects that don't. If ESLint is installed, the action is run. In projects without ESLint, the validation is skipped.
By default, committed files with a .js
or .mjs
extension will be checked. If you want to customize this,
e.g. to also validate TypeScript files, you can do so with the extensions
option, which accepts an array
with extensions of files to lint:
{
"pre-commit": {
"enabled": true,
"actions": [
{
"action": "\\Moxio\\CaptainHook\\ESLint\\ESLintAction",
"options": {
"extensions": [ "js", "mjs", "ts", "tsx" ]
}
}
]
}
}
This project adheres to Semantic Versioning.
This project is released under the MIT license.