Skip to content

Commit

Permalink
Fix workflow if react-scripts package is linked via npm-link (faceboo…
Browse files Browse the repository at this point in the history
…k#1356)

* add npm-link support

* - remove extra veriable
- simplify condition

* update code after review:
- remove utils/isReactScriptsLinked
- add appPath and ownPath to paths.js (but only for "before eject" export case)

* update code after review:
- remove utils/isReactScriptsLinked
- add appPath and ownPath to paths.js (but only for "before eject" export case)

* update code after review:
- remove utils/isReactScriptsLinked
- add appPath and ownPath to paths.js (but only for "before eject" export case)
- remove "if" block for fs.removeSync(ownPath) at ejec.tjs

* change ownPath value
  • Loading branch information
tuchk4 authored and randycoulman committed May 8, 2017
1 parent 8a1139d commit 469edf1
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 18 deletions.
37 changes: 22 additions & 15 deletions packages/react-scripts/config/paths.js
Original file line number Diff line number Diff line change
Expand Up @@ -94,11 +94,13 @@ module.exports = {

// @remove-on-eject-begin
function resolveOwn(relativePath) {
return path.resolve(__dirname, relativePath);
return path.resolve(__dirname, '..', relativePath);
}

// config before eject: we're in ./node_modules/react-scripts/config/
module.exports = {
appPath: resolveApp('.'),
ownPath: resolveApp('node_modules/react-scripts'),
appBuild: resolveApp(buildPath),
appPublic: resolveApp('client/public'),
appHtml: resolveApp('client/public/index.html'),
Expand All @@ -109,28 +111,33 @@ module.exports = {
testsSetup: resolveApp('client/setupTests.js'),
appNodeModules: resolveApp('node_modules'),
// this is empty with npm3 but node resolution searches higher anyway:
ownNodeModules: resolveOwn('../node_modules'),
ownNodeModules: resolveOwn('node_modules'),
nodePaths: nodePaths,
publicUrl: getPublicUrl(resolveApp('package.json')),
servedPath: getServedPath(resolveApp('package.json'))
};

var reactScriptsPath = path.resolve('node_modules/react-scripts');
var reactScriptsLinked = fs.existsSync(reactScriptsPath) && fs.lstatSync(reactScriptsPath).isSymbolicLink();

// config before publish: we're in ./packages/react-scripts/config/
if (__dirname.indexOf(path.join('packages', 'react-scripts', 'config')) !== -1) {
if (!reactScriptsLinked && __dirname.indexOf(path.join('packages', 'react-scripts', 'config')) !== -1) {
module.exports = {
appBuild: resolveOwn('../../../' + buildPath),
appPublic: resolveOwn('../template/client/public'),
appHtml: resolveOwn('../template/client/public/index.html'),
appIndexJs: resolveOwn('../template/client/index.js'),
appPackageJson: resolveOwn('../package.json'),
appSrc: resolveOwn('../template/client'),
yarnLockFile: resolveOwn('../template/yarn.lock'),
testsSetup: resolveOwn('../template/client/setupTests.js'),
appNodeModules: resolveOwn('../node_modules'),
ownNodeModules: resolveOwn('../node_modules'),
appPath: resolveApp('.'),
ownPath: resolveOwn('.'),
appBuild: resolveOwn('../../' + buildPath),
appPublic: resolveOwn('template/client/public'),
appHtml: resolveOwn('template/client/public/index.html'),
appIndexJs: resolveOwn('template/client/index.js'),
appPackageJson: resolveOwn('package.json'),
appSrc: resolveOwn('template/client'),
yarnLockFile: resolveOwn('template/yarn.lock'),
testsSetup: resolveOwn('template/client/setupTests.js'),
appNodeModules: resolveOwn('node_modules'),
ownNodeModules: resolveOwn('node_modules'),
nodePaths: nodePaths,
publicUrl: getPublicUrl(resolveOwn('../package.json')),
servedPath: getServedPath(resolveOwn('../package.json'))
publicUrl: getPublicUrl(resolveOwn('package.json')),
servedPath: getServedPath(resolveOwn('package.json'))
};
}
// @remove-on-eject-end
5 changes: 2 additions & 3 deletions packages/react-scripts/scripts/eject.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,8 @@ prompt(

console.log('Ejecting...');

var ownPath = path.join(__dirname, '..');
var appPath = path.join(ownPath, '..', '..');
var ownPath = paths.ownPath;
var appPath = paths.appPath;

function verifyAbsent(file) {
if (fs.existsSync(path.join(appPath, file))) {
Expand Down Expand Up @@ -135,7 +135,6 @@ prompt(
);

// Add Babel config

console.log(' Adding ' + cyan('Babel') + ' preset');
appPackage.babel = babelConfig;

Expand Down

0 comments on commit 469edf1

Please sign in to comment.