diff --git a/packages/nuxt/package.json b/packages/nuxt/package.json index bc92f809df6ef5..5e1632fbf9a0db 100644 --- a/packages/nuxt/package.json +++ b/packages/nuxt/package.json @@ -38,7 +38,9 @@ "@nx/vite": "file:../vite", "@phenomnomnominal/tsquery": "~5.0.1" }, - "peerDependencies": {}, + "peerDependencies": { + "@nuxt/schema": "^3.10.0" + }, "publishConfig": { "access": "public" } diff --git a/packages/nuxt/src/plugins/plugin.ts b/packages/nuxt/src/plugins/plugin.ts index 3fb80e9b3455cb..503835bac7b8ac 100644 --- a/packages/nuxt/src/plugins/plugin.ts +++ b/packages/nuxt/src/plugins/plugin.ts @@ -1,3 +1,4 @@ +import type { NuxtOptions } from '@nuxt/schema'; import { CreateDependencies, CreateNodes, @@ -8,13 +9,14 @@ import { workspaceRoot, writeJsonFile, } from '@nx/devkit'; -import { dirname, isAbsolute, join, relative } from 'path'; -import { workspaceDataDirectory } from 'nx/src/utils/cache-directory'; +import { loadConfigFile } from '@nx/devkit/src/utils/config-utils'; import { getNamedInputs } from '@nx/devkit/src/utils/get-named-inputs'; -import { existsSync, readdirSync } from 'fs'; import { calculateHashForCreateNodes } from '@nx/devkit/src/utils/calculate-hash-for-create-nodes'; +import { workspaceDataDirectory } from 'nx/src/utils/cache-directory'; import { getLockFileName } from '@nx/js'; -import { loadConfigFile } from '@nx/devkit/src/utils/config-utils'; +import { dirname, isAbsolute, join, relative } from 'path'; +import { existsSync, readdirSync } from 'fs'; +import { loadNuxtKitDynamicImport } from '../utils/executor-utils'; const cachePath = join(workspaceDataDirectory, 'nuxt.hash'); const targetsCache = readTargetsCache(); @@ -208,10 +210,16 @@ async function getInfoFromNuxtConfig( ): Promise<{ buildDir: string; }> { - // TODO(Colum): Once plugins are isolated we can go back to @nuxt/kit since each plugin will be run in its own worker. - const config = await loadConfigFile( - join(context.workspaceRoot, configFilePath) - ); + let config: NuxtOptions; + if (process.env.NX_ISOLATE_PLUGINS !== 'false') { + config = await ( + await loadNuxtKitDynamicImport() + ).loadNuxtConfig({ + configFile: configFilePath, + }); + } else { + config = await loadConfigFile(join(context.workspaceRoot, configFilePath)); + } return { buildDir: config?.buildDir ??