Global Implicit Dependencies

As of Nx 14.4, it is better to use inputs and namedInputs instead of the implicitDependencies previously defined in nx.json. implicitDependencies in the project configuration are still the best way to manually set up a dependency between two projects that Nx is not able to detect automatically.

Projects Depending on Global Files

The old way to have the myapp project depend on specific files in the root of the workspace was to use implicitDependencies, like this:

{ "implicitDependencies": { "globalConfig.js": ["myapp"], "styles/**/*.css": ["myapp"] } }

To express the same dependencies with inputs and namedInputs, modify the default sharedGlobals named input:

nx.json
{ "namedInputs": { "sharedGlobals": [ "{workspaceRoot}/globalConfig.js", "{workspaceRoot}/styles/**/*.css" ], "default": [ "sharedGlobals" // etc ] } }

The sharedGlobals are included in the default named input, so most targets will be set up to depend on them.

For a more detailed explanation, read the Customizing Inputs and Named Inputs guide

Dependencies on Sections of the Root package.json File

You used to be able to set up dependencies on specific packages in the dependenceis and devDependencies sections of the package.json file, like this:

{ "implicitDependencies": { "package.json": { "dependencies": "*", "devDependencies": { "mypackage": ["mylib"] } } } }

As of Nx 15, this is inferred automatically by Nx based on the import statements in your code. These implicitDependencies can be safely deleted.