This package provides eslint rules used by Digital Bazaar as a set of extendable shared configs.
There are various core rule sets:
@digitalbazaar/eslint-config: Base rules for both node and browser code.@digitalbazaar/eslint-config/import: Rules for es6 imports in the browser and node code.@digitalbazaar/eslint-config/jsdoc: Rules for JSDoc for both node and browser code.@digitalbazaar/eslint-config/module: Rules for modules for both node and browser code.@digitalbazaar/eslint-config/vue3: Rules for Vue 3 code.
For common use cases, there are recommended configs, that load the core rules:
@digitalbazaar/eslint-config/browser-recommended: Recommended rules for projects targeting web browsers.@digitalbazaar/eslint-config/node-recommended: Recommended rules for projects targeting node.@digitalbazaar/eslint-config/recommended: Common recommended rules.@digitalbazaar/eslint-config/universal-recommended: Recommended rules for projects targeting node and web browsers.@digitalbazaar/eslint-config/vue3-recommended: Recommended rules for projects targeting Vue 3.
Requires:
- eslint v9
npm i -D eslint@9
npm i -D @digitalbazaar/eslint-configTo start an eslint config file:
npx eslint --initOr copy a template from the examples/ directory:
cp node_modules/@digitalbazaar/eslint-config/examples/node-recommended.js ./eslint.config.jsNOTE: The core and recommended configs use dependencies that are automatically installed. Depending on the configs you use, there may be extra plugin dependencies installed that are not needed. This adds some development bloat but simplifies usage and dependency management. A future version may provide alternative slimmer packages with appropriate dependencies.
Notable dependencies that are always installed:
eslint-plugin-jsdoceslint-plugin-unicorneslint-plugin-vue:vue-eslint-parser(peer dependency of vue plugin)
Config files can use the simple array syntax or the defineConfig syntax
(see shareable configs).
Example eslint.config.js root setup:
import config from '@digitalbazaar/eslint-config/recommended'
export default [
...config
];Recommended configs (listed earlier) exist for common use cases. They may be sufficient on their own when using the opinionated code and file style used by Digital Bazaar for specific types of packages. However, they can also be mixed and matched and modified as needed. Note that currently required plugin dependencies must be manually installed when using recommended configs.
To use the import plugin rules you need to install
eslint-plugin-import:
npm i -D eslint-plugin-importExample eslint.config.js import setup:
import config from '@digitalbazaar/eslint-config/recommended'
import importConfig from '@digitalbazaar/eslint-config/import'
export default [
...config,
...importConfig
];Example eslint.config.js to explicitly use the JSDoc rules:
import config from '@digitalbazaar/eslint-config'
import jsdocConfig from '@digitalbazaar/eslint-config/jsdoc'
export default [
...config,
...jsdocConfig
];Example eslint.config.js to explicitly use ES module rules:
import config from '@digitalbazaar/eslint-config'
import moduleConfig from '@digitalbazaar/eslint-config/module'
export default [
...config,
...moduleConfig
];Example eslint.config.js to explicitly use Vue 3 rules:
import config from '@digitalbazaar/eslint-config'
import vue3Config from '@digitalbazaar/eslint-config/vue3'
export default [
...config,
...vue3Config
];For command line use you may need to explicitly enable linting .vue
files.
The core rules do not depend on each other and are composable:
import config from '@digitalbazaar/eslint-config'
import jsdocConfig from '@digitalbazaar/eslint-config/jsdoc'
import vue3Config from '@digitalbazaar/eslint-config/vue3'
export default [
...config,
...jsdoconfig,
...vue3Config
];Other rules that can be useful:
- Use
node:modulestyle for Node.js modules. - This is included in the node related recommended configs.
See unicorn/prefer-node-protocol.
Example eslint.config.js:
import config from '@digitalbazaar/eslint-config'
export default [
...config,
{
rules: {
'unicorn/prefer-node-protocol': 'error'
}
}
];Commercial support for this package is available upon request from Digital Bazaar: [email protected]
BSD-3-Clause Copyright 2025 Digital Bazaar, Inc.