mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-19 01:45:53 +00:00
fix(nuxt): don't resolve relative import type paths for deps (#29069)
This commit is contained in:
parent
466a98b6e0
commit
03342f8575
@ -178,13 +178,13 @@ async function initNuxt (nuxt: Nuxt) {
|
|||||||
|
|
||||||
const coreTypePackages = nuxt.options.typescript.hoist || []
|
const coreTypePackages = nuxt.options.typescript.hoist || []
|
||||||
const packageJSON = await readPackageJSON(nuxt.options.rootDir).catch(() => ({}) as PackageJson)
|
const packageJSON = await readPackageJSON(nuxt.options.rootDir).catch(() => ({}) as PackageJson)
|
||||||
const dependencies = new Set([...Object.keys(packageJSON.dependencies || {}), ...Object.keys(packageJSON.devDependencies || {})])
|
nuxt._dependencies = new Set([...Object.keys(packageJSON.dependencies || {}), ...Object.keys(packageJSON.devDependencies || {})])
|
||||||
const paths = Object.fromEntries(await Promise.all(coreTypePackages.map(async (pkg) => {
|
const paths = Object.fromEntries(await Promise.all(coreTypePackages.map(async (pkg) => {
|
||||||
const [_pkg = pkg, _subpath] = /^[^@]+\//.test(pkg) ? pkg.split('/') : [pkg]
|
const [_pkg = pkg, _subpath] = /^[^@]+\//.test(pkg) ? pkg.split('/') : [pkg]
|
||||||
const subpath = _subpath ? '/' + _subpath : ''
|
const subpath = _subpath ? '/' + _subpath : ''
|
||||||
|
|
||||||
// ignore packages that exist in `package.json` as these can be resolved by TypeScript
|
// ignore packages that exist in `package.json` as these can be resolved by TypeScript
|
||||||
if (dependencies.has(_pkg) && !(_pkg in nightlies)) { return [] }
|
if (nuxt._dependencies?.has(_pkg) && !(_pkg in nightlies)) { return [] }
|
||||||
|
|
||||||
// deduplicate types for nightly releases
|
// deduplicate types for nightly releases
|
||||||
if (_pkg in nightlies) {
|
if (_pkg in nightlies) {
|
||||||
|
@ -166,8 +166,9 @@ function addDeclarationTemplates (ctx: Unimport, options: Partial<ImportsOptions
|
|||||||
|
|
||||||
async function cacheImportPaths (imports: Import[]) {
|
async function cacheImportPaths (imports: Import[]) {
|
||||||
const importSource = Array.from(new Set(imports.map(i => i.from)))
|
const importSource = Array.from(new Set(imports.map(i => i.from)))
|
||||||
|
// skip relative import paths for node_modules that are explicitly installed
|
||||||
await Promise.all(importSource.map(async (from) => {
|
await Promise.all(importSource.map(async (from) => {
|
||||||
if (resolvedImportPathMap.has(from)) {
|
if (resolvedImportPathMap.has(from) || nuxt._dependencies?.has(from)) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
let path = resolveAlias(from)
|
let path = resolveAlias(from)
|
||||||
@ -176,6 +177,8 @@ function addDeclarationTemplates (ctx: Unimport, options: Partial<ImportsOptions
|
|||||||
if (!r) { return r }
|
if (!r) { return r }
|
||||||
|
|
||||||
const { dir, name } = parseNodeModulePath(r)
|
const { dir, name } = parseNodeModulePath(r)
|
||||||
|
if (name && nuxt._dependencies?.has(name)) { return from }
|
||||||
|
|
||||||
if (!dir || !name) { return r }
|
if (!dir || !name) { return r }
|
||||||
const subpath = await lookupNodeModuleSubpath(r)
|
const subpath = await lookupNodeModuleSubpath(r)
|
||||||
return join(dir, name, subpath || '')
|
return join(dir, name, subpath || '')
|
||||||
|
@ -76,6 +76,7 @@ export interface Nuxt {
|
|||||||
// Private fields.
|
// Private fields.
|
||||||
_version: string
|
_version: string
|
||||||
_ignore?: Ignore
|
_ignore?: Ignore
|
||||||
|
_dependencies?: Set<string>
|
||||||
|
|
||||||
/** The resolved Nuxt configuration. */
|
/** The resolved Nuxt configuration. */
|
||||||
options: NuxtOptions
|
options: NuxtOptions
|
||||||
|
Loading…
Reference in New Issue
Block a user