From d394d82281cc4fb039fac1fc17122e241c692963 Mon Sep 17 00:00:00 2001 From: Norbert de Langen <ndelangen@me.com> Date: Fri, 9 Nov 2018 08:51:14 +0000 Subject: [PATCH] Merge pull request #4712 from mrmckeb/feature/custom-react-scripts Add support for custom `react-scripts` packages --- app/react/src/server/cra_config.js | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/app/react/src/server/cra_config.js b/app/react/src/server/cra_config.js index 23d3a781d2d0..b94dfffcff6e 100644 --- a/app/react/src/server/cra_config.js +++ b/app/react/src/server/cra_config.js @@ -1,12 +1,25 @@ +import fs from 'fs'; +import path from 'path'; import semver from 'semver'; import MiniCssExtractPlugin from 'mini-css-extract-plugin'; import { normalizeCondition } from 'webpack/lib/RuleSet'; +let reactScriptsPath; +function getReactScriptsPath() { + if (reactScriptsPath) return reactScriptsPath; + const appDirectory = fs.realpathSync(process.cwd()); + const reactScriptsScriptPath = fs.realpathSync( + path.join(appDirectory, '/node_modules/.bin/react-scripts') + ); + reactScriptsPath = path.join(reactScriptsScriptPath, '../..'); + return reactScriptsPath; +} + export function isReactScriptsInstalled() { try { - // eslint-disable-next-line global-require, import/no-extraneous-dependencies - const reactScriptsJson = require('react-scripts/package.json'); + // eslint-disable-next-line global-require, import/no-dynamic-require + const reactScriptsJson = require(path.join(getReactScriptsPath(), 'package.json')); if (semver.lt(reactScriptsJson.version, '2.0.0')) return false; return true; } catch (e) { @@ -42,12 +55,12 @@ export function getStyleRules(rules) { export function getCraWebpackConfig(mode) { if (mode === 'production') { - // eslint-disable-next-line global-require, import/no-extraneous-dependencies - return require('react-scripts/config/webpack.config.prod'); + // eslint-disable-next-line global-require, import/no-dynamic-require + return require(path.join(getReactScriptsPath(), 'config/webpack.config.prod')); } - // eslint-disable-next-line global-require, import/no-extraneous-dependencies - return require('react-scripts/config/webpack.config.dev'); + // eslint-disable-next-line global-require, import/no-dynamic-require + return require(path.join(getReactScriptsPath(), 'config/webpack.config.dev')); } export function applyCRAWebpackConfig(baseConfig) {