diff --git a/docs/docs/docs/api/config.md b/docs/docs/docs/api/config.md index ec3998adf07a1..0c4dc6af78b11 100644 --- a/docs/docs/docs/api/config.md +++ b/docs/docs/docs/api/config.md @@ -1058,7 +1058,7 @@ mountElementId: 'container' ## monorepoRedirect -- 类型:`{ srcDir?: string[], exclude?: RegExp[], peerDeps?: boolean }` +- 类型:`{ srcDir?: string[], exclude?: RegExp[], peerDeps?: boolean, pkgUpFromCurrentProjectRoot?: boolean }` - 默认值:`false` 在 monorepo 中使用 Umi 时,你可能需要引入其他子包的组件、工具方法等,通过开启此选项来重定向这些子包的导入到他们的源码位置(默认为 `src` 文件夹),这也可以解决 `MFSU` 场景改动子包不热更新的问题。 @@ -1098,6 +1098,8 @@ monorepoRedirect: { peerDeps: true } 经过重定向,依赖全局唯一,便可以在开发时保持和在 npm 上安装包后的体验一致。 +pkgUpFromCurrentProjectRoot: 如果项目使用 umi 作为主应用并有 monorepo 管理子包,可配置 `pkgUpFromCurrentProjectRoot: true`, 将从当前项目目录查找 package.json 从而实现 monorepoRedirect + ## mpa - 类型:`object` diff --git a/packages/preset-umi/src/features/monorepo/redirect.ts b/packages/preset-umi/src/features/monorepo/redirect.ts index 31ae197ee687a..9df205879bfc3 100644 --- a/packages/preset-umi/src/features/monorepo/redirect.ts +++ b/packages/preset-umi/src/features/monorepo/redirect.ts @@ -11,6 +11,7 @@ interface IConfigs { srcDir?: string[]; exclude?: RegExp[]; peerDeps?: boolean; + pkgUpFromCurrentProjectRoot?: boolean; } export default (api: IApi) => { @@ -34,10 +35,19 @@ export default (api: IApi) => { }); api.modifyConfig(async (memo) => { + const config: IConfigs = memo.monorepoRedirect || {}; + const { + exclude = [], + srcDir = ['src'], + peerDeps = false, + pkgUpFromCurrentProjectRoot = false, + } = config; const currentProjectRoot = process.env.APP_ROOT ? process.cwd() : api.cwd; const rootPkg = await pkgUp({ // APP_ROOT: https://github.com/umijs/umi/issues/9461 - cwd: dirname(currentProjectRoot), + cwd: pkgUpFromCurrentProjectRoot + ? currentProjectRoot + : dirname(currentProjectRoot), }); if (!rootPkg) return memo; const root = dirname(rootPkg); @@ -46,8 +56,6 @@ export default (api: IApi) => { `The 'monorepoRedirect' option can only be used in monorepo, you don't need configure.`, ); - const config: IConfigs = memo.monorepoRedirect || {}; - const { exclude = [], srcDir = ['src'], peerDeps = false } = config; // Note: not match `umi` package in local dev if (isLocalDev()) { logger.info( diff --git a/packages/umi/client/client/plugin.js b/packages/umi/client/client/plugin.js index 8fa92fa7f465d..6863e23a065b8 100644 --- a/packages/umi/client/client/plugin.js +++ b/packages/umi/client/client/plugin.js @@ -215,4 +215,4 @@ export var PluginManager = /*#__PURE__*/function () { }(); // plugins meta info (in tmp file) -// hooks api: usePlugin \ No newline at end of file +// hooks api: usePlugin