Shared eslint configurations, useful plugins & custom rules.
Inside of lib/config you'll find a set of configs for different environments + base.js.
Base.js effectively documents our code style. Please make sure any rules you add come with an explanation!
- Make sure that
gstenv
is green. See our Dev Environment docs. git clone
this repo &cd
into it as usual- Run
yarn install
to install dependencies.
Run yarn link
inside of me, and then run yarn link eslint-plugin-ghost
inside of the project you want to lint.
- Inside of package.json, add this rule:
"lint": "eslint . --ext .js --cache"
- Then, in your project root, create an
.eslintrc.js
file, and add the following code:
module.exports = {
plugins: ['ghost'],
extends: [
'plugin:ghost/[config]',
]
};
- Change
[config]
to be E.g. node, browser, test etc depending on what environment you are linting - If you have a test folder, browser JS, etc, you can add multiple
.eslintrc.js
files, nesting them inside the folder they belong to.
yarn ship
-yarn ship
Copyright (c) 2013-2025 Ghost Foundation - Released under the MIT license. Ghost and the Ghost Logo are trademarks of Ghost Foundation Ltd. Please see our trademark policy for info on acceptable usage.