@nx/workspace

The workspace plugin contains executors and generators that are useful for any Nx workspace. It should be present in every Nx workspace and other plugins build on it.

Creating Local Generators

Codifying your organization's best practices into local generators is a great way to ensure that the best practices are easy to follow and implement. Running nx g @nx/plugin:plugin packages/feature will create a local plugin with a generator which is written the same way generators are written for Nx plugins.

See more about local generators

Reorganizing Projects

After some time of working within a workspace, projects might need to be moved or sometimes even removed. The workspace plugin provides the @nx/workspace:move and @nx/workspace:remove generators to help aid with this.

Moving Projects

Running nx g @nx/workspace:move --projectName my-lib --destination new/location/my-lib will move the my-lib library to libs/new/location/my-lib.

Moving the files manually can be done easily but a lot of steps are often missed when projects are moved. This generator will also handle the following:

  1. The project's files will be moved
  2. The project will be renamed to new-location-my-lib
  3. The path mapping in tsconfig.base.json will be changed to @npmScope/new/location/my-lib
  4. Imports in other projects will be changed to @npmScope/new/location/my-lib
  5. Paths in target options such as output path will be changed
  6. Other configuration will be updated too, such as extends in tsconfig.json, the name of the project in jest.config.js, and the extends in .eslintrc.json

See more about @nx/workspace:move

Removing Projects

Running nx g @nx/workspace:remove my-lib will remove the my-lib from the workspace. It is important to note that sometimes, projects cannot be removed if they are still depended on by other projects.

Like when moving projects, some steps are often missed when removing projects. This generator will also handle the following:

  1. Checks if other projects depend on the project being removed. This can be ignored via the --forceRemove flag.
  2. The project's files will be deleted.
  3. The project's configuration will be removed.
  4. The path mapping in tsconfig.base.json will be removed.

See more about @nx/workspace:remove

Package reference

Here is a list of all the executors, generators and migrations available from this package.

Guides

Executors

  • counterInternal

    A dummy executor useful for E2E tests.

Generators

Migrations

  • 20.2.x

  • 20.2.0-package-updates

    Version: 20.2.0-beta.5

    Requires

    NameVersion
    typescript>=5.5.0 <5.6.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.6.2Update only
  • 19.5.x

  • 19.5.1-package-updates

    Version: 19.5.0-beta.1

    Requires

    NameVersion
    typescript>=5.4.0 <5.5.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.5.2Update only
  • 18.2.x

  • 18.2.0-package-updates

    Version: 18.2.0-beta.0

    Requires

    NameVersion
    typescript>=5.3.0 <5.4.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.4.2Update only
  • 17.3.x

  • 17.3.0-package-updates

    Version: 17.3.0-beta.10

    Requires

    NameVersion
    typescript>=5.2.0 <5.3.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.3.2Update only
  • 17.1.x

  • 17.1.0-package-updates

    Version: 17.1.0-beta.4

    Requires

    NameVersion
    typescript>=5.1.0 <5.2.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.2.2Update only