From b4e72a54966bda12ef70791f09df5cbe0f04b889 Mon Sep 17 00:00:00 2001 From: JounQin Date: Sun, 30 Jun 2019 16:36:43 +0800 Subject: [PATCH] feat: support scoped packages from DefinitelyTyped --- index.js | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/index.js b/index.js index 1f577d6..4c8ff3b 100644 --- a/index.js +++ b/index.js @@ -66,13 +66,17 @@ function resolveFile(source, file, config) { // iff path is neither absolute nor relative if ( /\.jsx?$/.test(foundNodePath) && - !/^@types[\/\\]/.test(source) && + !/^@types[/\\]/.test(source) && !path.isAbsolute(source) && source[0] !== '.' ) { - const definitely = resolveFile('@types/' + source, file, config); - if (definitely.found) { - return definitely; + const definitelyTyped = resolveFile( + '@types' + path.sep + mangleScopedPackage(source), + file, + config, + ); + if (definitelyTyped.found) { + return definitelyTyped; } } @@ -91,12 +95,29 @@ function resolveFile(source, file, config) { found: false, }; } + function packageFilter(pkg) { pkg.main = pkg.types || pkg.typings || pkg.module || pkg['jsnext:main'] || pkg.main; return pkg; } +/** + * For a scoped package, we must look in `@types/foo__bar` instead of `@types/@foo/bar`. + * + * @param {string} moduleName + * @returns {string} + */ +function mangleScopedPackage(moduleName) { + if (moduleName[0] === '@') { + const replaceSlash = moduleName.replace(path.sep, '__'); + if (replaceSlash !== moduleName) { + return replaceSlash.slice(1); // Take off the "@" + } + } + return moduleName; +} + module.exports = { interfaceVersion: 2, resolve: resolveFile,