noUndeclaredDependencies
Summary
Section titled “Summary”- Rule available since:
v1.6.0
- Diagnostic Category:
lint/correctness/noUndeclaredDependencies
- This rule doesn’t have a fix.
- The default severity of this rule is error.
- This rule belongs to the following domains:
- Sources:
Description
Section titled “Description”Disallow the use of dependencies that aren’t specified in the package.json
.
Indirect dependencies will trigger the rule because they aren’t declared in the package.json
.
This means that if the package @org/foo
has a dependency on lodash
, and then you use
import "lodash"
somewhere in your project, the rule will trigger a diagnostic for this import.
The rule is meant to catch those dependencies that aren’t declared inside the closest package.json
, and
isn’t meant to detect dependencies declared in other manifest files, e.g. the root package.json
in a monorepo setting.
The rule ignores imports that are not valid package names.
This includes internal imports that start with #
and @/
and imports with a protocol such as node:
, bun:
, jsr:
, https:
.
To ensure that Visual Studio Code uses relative imports when it automatically imports a variable,
you may set javascript.preferences.importModuleSpecifier
and typescript.preferences.importModuleSpecifier
to relative
.
Examples
Section titled “Examples”Invalid
Section titled “Invalid”import "vite";
import { A } from "./local.js";
import assert from "node:assert";
If you have declared type-fest
in the devDependencies
section:
import type { SetRequired } from "type-fest";
Options
Section titled “Options”This rule supports the following options:
devDependencies
: If set tofalse
, then the rule will show an error whendevDependencies
are imported. Defaults totrue
.peerDependencies
: If set tofalse
, then the rule will show an error whenpeerDependencies
are imported. Defaults totrue
.optionalDependencies
: If set tofalse
, then the rule will show an error whenoptionalDependencies
are imported. Defaults totrue
.
You can set the options like this:
{ "options": { "devDependencies": false, "peerDependencies": false, "optionalDependencies": false }}
You can also use an array of globs instead of literal booleans.
When using an array of globs, the setting will be set to true
(no errors reported)
if the name of the file being linted (i.e. not the imported file/module) matches a single glob
in the array, and false
otherwise.
In the following example, only test files can use dependencies in devDependencies
section.
dependencies
, peerDependencies
, and optionalDependencies
are always available.
{ "options": { "devDependencies": ["tests/*.test.js", "tests/*.spec.js"] }}
How to configure
Section titled “How to configure”{ "linter": { "rules": { "correctness": { "noUndeclaredDependencies": "error" } } }}
Related links
Section titled “Related links”Copyright (c) 2023-present Biome Developers and Contributors.