Hi everyone! We just released what we hope to be the last beta before v2 is marked stable and tagged latest
on npm tomorrow.
Please try it as soon as possible and let us know if you run into any issues!
Create new application:
$ npx create-react-app@next --scripts-version=@next test-next
Upgrade existing:
$ npm install react-scripts@next --save
$ # or
$ yarn add react-scripts@next
Here's a draft of the release notes:
node_modules
now workInside any created project that has not been ejected, run:
$ npm install --save --save-exact [email protected]
$ # or
$ yarn add --exact [email protected]
Next, follow the migration instructions below that are relevant to you.
require.ensure()
We previously allowed code splitting with a webpack-specific directive, require.ensure()
. It is now disabled in favor of import()
.
To switch to import()
, follow the examples below:
Single Module
require.ensure(['module-a'], function() {
var a = require('module-a');
// ...
});
// Replace with:
import('module-a').then(a => {
// ...
});
Multiple Module
require.ensure(['module-a', 'module-b'], function() {
var a = require('module-a');
var b = require('module-b');
// ...
});
// Replace with:
Promise.all([import('module-a'), import('module-b')]).then(([a, b]) => {
// ...
});
jsdom
Look at the test
entry in the scripts
section of your package.json
.
Here's a table how to change it from "before" and "after", depending on what you have there:
| 1.x (if you have this...) | 2.x (...change it to this!) |
| - | - |
| react-scripts test --env=jsdom
| react-scripts test
|
| react-scripts test
| react-scripts test --env=node
|
.mjs
file extension support was removedChange the extension of any files in your project using .mjs
to just .js
.
It was removed because of inconsistent support from underlying tools. We will add it back after it stops being experimental, and Jest gets built-in support for it.
src/setupProxy.js
This change is only required for individuals who used the advanced proxy configuration in v1.
To check if action is required, look for the proxy
key in package.json
. Then, follow the table below.
proxy
key in package.json
proxy
is a string (e.g. http://localhost:5000
)proxy
is an objectIf your proxy
is an object, that means you are using the advanced proxy configuration.
Again, if your proxy
field is a string
, e.g. http://localhost:5000
, you do not need to do anything. This feature is still supported and has the same behavior.
First, install http-proxy-middleware
using npm or Yarn:
$ npm install http-proxy-middleware --save
$ # or
$ yarn add http-proxy-middleware
Next, create src/setupProxy.js
and place the following contents in it:
const proxy = require('http-proxy-middleware')
module.exports = function(app) {
// ...
}
Now, migrate each entry in your proxy
object one by one, e.g.:
"proxy": {
"/api": {
"target": "http://localhost:5000/"
},
"/*.svg": {
"target": "http://localhost:5000/"
}
}
Place entries into src/setupProxy.js
like so:
const proxy = require('http-proxy-middleware')
module.exports = function(app) {
app.use(proxy('/api', { target: 'http://localhost:5000/' }))
app.use(proxy('/*.svg', { target: 'http://localhost:5000/' }))
}
You can also use completely custom logic there now! This wasn't possible before.
We have dropped default support for Internet Explorer 9, 10, and 11. If you still need to support these browsers, follow the instructions below.
First, install react-app-polyfill
:
$ npm install react-app-polyfill --save
$ # or
$ yarn add react-app-polyfill
Next, place one of the following lines at the very top of src/index.js
:
import 'react-app-polyfill/ie9'; // For IE 9-11 support
import 'react-app-polyfill/ie11'; // For IE 11 support
You can read more about these polyfills here.
import()
has changedWebpack 4 changed the behavior of import()
to be closer in line with the specification.
Previously, importing a CommonJS module did not require you specify the default export. In most cases, this is now required.
If you see errors in your application about ... is not a function
, you likely need to update your dynamic import, e.g.:
const throttle = await import("lodash/throttle");
// replace with
const throttle = await import("lodash/throttle").then(m => m.default);
This was a large release, and we might have missed something.
PleaseΒ file an issueΒ and we will try to help.
If you used 2.x alphas, please follow these instructions.
>> TODO <<
I'm a bit late to the party. What do you mean with "node_modules
are now compiled"?
I reworded to
Packages using new JavaScript features in node_modules now work
Does this make more sense?
I'm a bit late to the party. What dou you mean with "
node_modules
are now compiled"?
node_modules
bundled with the app?
Thanks @gaearon, I was about to ask the same thing ^.^
I don't think I've ever needed it, but I guess it's nice it's there. Maybe this'll help build proper "goto definition" functionality, right now it keeps jumping to compiled js, and it's a mess.
Does this make more sense?
Yes. Thanks Dan!
I don't think I've ever needed it, but I guess it's nice it's there. Maybe this'll help build proper "goto definition" functionality, right now it keeps jumping to compiled js, and it's a mess.
I think there is some kind of misunderstanding here.
Previously, if somebody published a package that used newer syntax like const
, and you imported that package, your app wouldn't build. We've had dozens of issues filed about this. See all issues linked from https://github.com/facebook/create-react-app/issues/1125. Now it will work.
Have an issue with @next
:
When specified, "proxy" in package.json must be a string.
Instead, the type of "proxy" was "object".
Either remove "proxy" from package.json, or make it a string.
Actually, there was pretty extensive amount of options for proxy, are they all gone? With target
, pathRewrite
etc.
I used them on alpha as well.
@z-ax this is not a bug -- we removed the proxy options. Please read the migration instructions above. π
Good job everyone working on wrapping up the 2.0 release! Thanks for your efforts!
Just tried here. It works. One question:
Why it says 1
instead of vendor
? I guess that's the vendor
bundle.
What if I have async routes and don't want to name them? Can I customize the vendor bundle name?
@Timer I don't see it in docs right here and it was working with the most recent alpha.
How should we migrate now without proxy? Why even it was removed? Very helpful for dev envs.
Edit: see it in Roadmap, don't see new docs on this.
@z-ax You can now provide a custom express middleware function as a proxy: https://github.com/facebook/create-react-app/pull/5073. This should give you complete control over the proxy.
Are you planning on getting the typescript PR in or will that come in a minor update post 2.0 release?
@z-ax added the preliminary docs here: https://github.com/facebook/create-react-app/commit/54323f07dc2cd4b0d8ee5cf33d584db75fc0e938
The migration instructions above explain exactly how to migrate in the mean time.
@Timer @gaearon Big changes! π· Would you please point to the PR that enables babel for node_modules
?
Have an errors when using flow in node_modules packages (using yarn workspace)
@pi0 https://github.com/facebook/create-react-app/pull/3776
@meafmira support for workspaces was dropped. Please see the migration instructions (we know they're not great, but we'll be improving them).
@Timer thanks, everything seems working.
But +1 to @zaguiini about file naming. I liked vendors
more, now just have 2 chunks :)
Btw, is it something on my side that chunk 1 has content like this? As I can remember, always had this one on build, for maybe a year or so: (window.webpackJsonp=window.webpackJsonp||[]).push([[1],{1024:function(n,w,o){}}]);
.
Have errors when using flow in node_modules packages and socket.io
Please file an issue with more details @sumitsg10 and a reproducible demo.
@z-ax naming is pretty arbitrary and actually caused really bad behavior for larger apps. I don't think anyone but you (the developer) will ever notice. :-)
I don't think it's expected for Flow to work inside node_modules
. We only compile standard JavaScript features inside node_modules
. This is an intentional design choice to avoid the churn when proposals change, or new versions of Babel come out. You can ask React Native users about how Babel 7 upgrade went for them.
Just a question: Why use modules: false
for dependencies in test env?
@lixiaoyan see the above message from @gaearon, the same reasoning applies
naming is pretty arbitrary and actually caused really bad behavior for larger apps. I don't think anyone but you (the developer) will ever notice. :-)
Yup, main
is also "pretty arbitrary". Lots of people use vendor
as their vendor bundle.
main
's also a convention. Why not drop main
too? See the point?
We make no guarantee that a chunk only contains node_modules
, as it could be a mix of node_modules
and app code.
You can read https://github.com/facebook/create-react-app/issues/4977, https://github.com/facebook/create-react-app/issues/4633, https://github.com/facebook/create-react-app/issues/4632 and a few others to learn why putting all of node_modules
into a vendor chunk is a bad idea.
Feel free to open an issue with webpack to change the default name of the main
chunk to a number.
@Timer Here are two problems with Jest & Babel:
node_modules
.node_modules
in test env (modules: false
disable module transform).which causes:
So we may need to:
node_modules
with different Babel presets.modules: 'commonjs'
for @babel/preset-env
in test env.It will make the transform behavior between Jest and Webpack more consistent.
(ES Module is standard JavaScript feature)
Upgraded an [email protected] app with ~16kloc of React related code and everything was nearly painless:
eslint
dependency to @^5
. The error message for this was long but awesome!jest
related changes a single test with lots of mocking now hangs and snapshots that use jest.mock() failed: no biggieI don't think I've ever needed it, but I guess it's nice it's there. Maybe this'll help build proper "goto definition" functionality, right now it keeps jumping to compiled js, and it's a mess.
I think there is some kind of misunderstanding here.
Previously, if somebody published a package that used newer syntax like
const
, and you imported that package, your app wouldn't build. We've had dozens of issues filed about this. See all issues linked from #1125. Now it will work.
You're absolutely right! I personally have never had this happen, because most packages seem to come pre-transpiled =)
@Timer Another problem: Babel config may be overridden by a babel.config.js
file, option babelrc: false
is not enough to prevent config overwritten, setting option configFile: false
is needed.
Nice catch, @lixiaoyan! Can you please send a PR disabling this?
Installing packages. This might take a couple of minutes.
Installing react, react-dom, and react-scripts...
yarn add v1.9.4
info No lockfile found.
[1/4] Resolving packages...
error Couldn't find package "@xtuc/[email protected]" required by "@webassemblyjs/[email protected]" on the "npm" registry.
info Visit https://yarnpkg.com/en/docs/cli/add for documentation about this command.
Error: Couldn't find package "@xtuc/[email protected]" required by "@webassemblyjs/[email protected]" on the "npm" registry.
at MessageError.ExtendableBuiltin (C:\Program Files (x86)\Yarn\lib\cli.js:243:66)
at new MessageError (C:\Program Files (x86)\Yarn\lib\cli.js:272:123)
at PackageRequest.<anonymous> (C:\Program Files (x86)\Yarn\lib\cli.js:38988:17)
at Generator.throw (<anonymous>)
at step (C:\Program Files (x86)\Yarn\lib\cli.js:92:30)
at C:\Program Files (x86)\Yarn\lib\cli.js:105:13
at <anonymous>
at process._tickCallback (internal/process/next_tick.js:188:7)
Error: Couldn't find package "@xtuc/[email protected]" required by "@webassemblyjs/[email protected]" on the "npm" registry.
at MessageError.ExtendableBuiltin (C:\Program Files (x86)\Yarn\lib\cli.js:243:66)
at new MessageError (C:\Program Files (x86)\Yarn\lib\cli.js:272:123)
at PackageRequest.<anonymous> (C:\Program Files (x86)\Yarn\lib\cli.js:38988:17)
at Generator.throw (<anonymous>)
at step (C:\Program Files (x86)\Yarn\lib\cli.js:92:30)
at C:\Program Files (x86)\Yarn\lib\cli.js:105:13
at <anonymous>
at process._tickCallback (internal/process/next_tick.js:188:7)
Error: Couldn't find package "@xtuc/ieee754@^1.2.0" required by "@webassemblyjs/[email protected]" on the "npm" registry.
at MessageError.ExtendableBuiltin (C:\Program Files (x86)\Yarn\lib\cli.js:243:66)
at new MessageError (C:\Program Files (x86)\Yarn\lib\cli.js:272:123)
at PackageRequest.<anonymous> (C:\Program Files (x86)\Yarn\lib\cli.js:38988:17)
at Generator.throw (<anonymous>)
at step (C:\Program Files (x86)\Yarn\lib\cli.js:92:30)
at C:\Program Files (x86)\Yarn\lib\cli.js:105:13
at <anonymous>
at process._tickCallback (internal/process/next_tick.js:188:7)
Aborting installation.
yarnpkg add --exact react react-dom react-scripts@next --cwd C:\Users\s5201911\Desktop\test-next has failed.
Deleting generated file... package.json
Deleting test-next/ from C:\Users\s5201911\Desktop
Done.
Targetable CSS support
Did CRA uses Browserslist only for Autoprefixer?
Should we change ChangeLog or CRAβs Babel config?
@ai browserslist is only used for CSS. There were too many edge cases where browser target support for babel did not "just work", unfortunately. This is by no fault browserslist's, it seemed to be more of an issue with preset-env
.
I'm getting this error when trying to build,
Module build failed: Cannot read property 'type' of undefined
at Array.some (<anonymous>)
at Array.forEach (<anonymous>)
No file or line number is printed :confused: and my code doesn't have .some
in it. Sadly it's a private repo so I can't share the code.
@holloway Can you please file a new issue with a reproducing project, please?
@Timer
browserslist is only used for CSS. There were too many edge cases where browser target support for babel did not "just work", unfortunately. This is by no fault browserslist's, it seemed to be more of an issue with preset-env.
Can you show edge case examples? I will try to find people who will fix the source of the problem.
Did a fresh install and it works a charm π
Anyone has an idea of how to make babel-plugin-react-css-modules
work without ejecting? I've read that this could be accomplished with Babel Macros but I have no idea how to write one for this.
The idea is to have styleName
work without ejecting, as well as gaining all the performance benefits while not having to eject.
You'd need a macro, @davidalejandroaguilar.
I updated one of our apps from 1.1.1
to next
and it worked pretty well. Few jsx-a11y
warnings showed up (easy to fix), but start
, test
and build
scripts were without errors. :tada:
@Timer I don't know how to write plugins/macros, if this is the case, do I need to stick with having to import styles as an object and using className
?
I'm still concerned about that performance regression that Webpack 4 has. I mentioned it here in connection to CRA's dependence on Webpack 4.
I'm not sure whether sokra
's recommendation there (to use the terser-webpack-plugin
if possible) will work without ejecting from CRA, but it seems like something could/should be mentioned somewhere. I checked for any mention in the branch and didn't see any.
I know a number of devs have chewed up a lot of time chasing down this mysterious issue. Anyone using CRA and Font Awesome v5 (as well as any other libraries that have similar layouts as ours that would hit this perf regression) may soon find themselves joining in that debugging party.
It plagues some angular-cli users already.
Hmm, we can definitely switch back to uglify if it's more performant.
We could also profile Terser a bit and see if there's low hanging fruit.
I too have this question from @stramel above:
Are you planning on getting the typescript PR in or will that come in a minor update post 2.0 release?
Given that #4837 is not yet closed, and not yet even building on CI, I assume the answer is not now. But I hope not too long from now π π π
BTW, great work! This looks amazing regardless.
In v1 I could use decorators by using react-app-rewired, is it still the case with v2?
I'm getting this error when running my tests, any clue what it could be?
FAIL src/app/any_of_the_test_file.test.js
β Test suite failed to run
ReferenceError: self is not defined
at node_modules/react-app-polyfill/node_modules/whatwg-fetch/dist/fetch.umd.js:8:40
at Object.<anonymous>.support.searchParams (node_modules/react-app-polyfill/node_modules/whatwg-fetch/dist/fetch.umd.js:2:66)
at Object.<anonymous> (node_modules/react-app-polyfill/node_modules/whatwg-fetch/dist/fetch.umd.js:5:2)
at Object.<anonymous> (node_modules/react-app-polyfill/jsdom.js:10:1)
This happens for all tests.
I've changed my test command from react-scripts test --env=jsdom
to react-scripts test --env=node
.
If I run the tests with the jsdom
version I get all kinds of errors, like TypeError: Cannot read property 'bind' of undefined
on values that are not undefined
.
@Gpx
If you previously disabled jsdom, you may have removed the --env=jsdom flag. Make sure your test script in package.json contains the --env=node flag
That means:
| 1.0 | 2.0 |
| - | - |
| react-scripts test --env=jsdom
| react-scripts test
|
| react-scripts test
| react-scripts test --env=node
|
So you just need to remove --env=jsdom
but not add --env=node
.
@lixiaoyan thanks, I didn't understand it.
I modified it and now the error is this
Requires Babel "^7.0.0-0", but was loaded with "6.26.0". If you are sure you have a compatible version of @babel/core, it is likely that something in your build process is loading the wrong version. Inspect the stack trace of this error to look for the first entry that doesn't mention "@babel/core" or "babel-core" to see what is calling Babel. (While processing preset: "/node_modules/babel-preset-react-app/index.js")
I followed this comment https://github.com/facebook/jest/issues/6913#issuecomment-423684647 and that fixed it.
Now I'm having a lot of errors about TypeError: Cannot read property 'bind' of undefined
after existing project update when starting the app I get an error
./node_modules/apollo-link-state/lib/utils.js 27:51-56
'graphql' does not contain an export named 'print'.
all dependencies are at their latest versions and graphql does contain export named print and it worked fine before the cra update π€
@davidalekna
all dependencies are at their latest versions and graphql does contain export named print and it worked fine before the cra update
Provide a reproducing project please?
@Gpx
I followed this comment facebook/jest#6913 (comment) and that fixed it.
Itβs not clear how you βfollowedβ it because this comment didnβt contain any instructions. If you installed some package manually you probably further broke your setup.
Please revert your change (whatever it was), remove node_modules, reinstall them, and then file a new issue with your project (or a small reproducing case).
@binarylogician
In v1 I could use decorators by using react-app-rewired, is it still the case with v2?
The current maintainer of rewired
is not planning to support 2.x but maybe somebody else wants to step in?
That said thereβs a good reason we didnβt (and still donβt) support decorators. Are you aware that the specification changed and the old syntax and API is never going to be a standard? Now thereβs going to be churn for everybody who used old decorators. We shielded our users from this by not allowing them. You might want to reconsider using decorators until the transform is more stable and stops changing.
@gaearon I've created a reproduction and it seems to work... It might be specific to my use case as I'm using react-app-rewired to transpile "shared" directory which is outside of src... As I've noticed react-app-rewired will not support react-scripts@2... I was wondering if there is another way of achieving this? (without ejecting...)
Thanks
@gaearon I'm experiencing the same bug as @davidalekna
I created a project in which you can reproduce it: https://github.com/albertorestifo/create-react-app-apollo-bug
See this commit for all the changes I did on top of the out-of-the-box react app: https://github.com/albertorestifo/create-react-app-apollo-bug/commit/efa5cc384b913381b5740e6ad14e91009041a2b2
@davidalekna Existing rewires won't work with 2.x. Sorry we didn't make this clear. That's the kind of risk you were taking when you added rewires. AFAIK the project maintainer is not planning to support 2.x but maybe somebody else will take over it.
It might be specific to my use case as I'm using react-app-rewired to transpile "shared" directory which is outside of src..
We'll definitely want to figure out some way of doing it but you're right it's not yet supported. Maybe later in 2.x.
@albertorestifo Appreciated. We'll take a look.
@davidalekna should be easy to modify react-app-rewire to work with 2.0, we started work on migrating back before the summer but neither me or the original author works on related projects atm therefor have incentive to fix it right away. you can always submit a PR :)
In the README it still states on line 1002: ... Create React App includes a polyfill for fetch() so you can use it without worrying about the browser support.
I do however believe all polyfill have been removed, hence this sentence should also be updated/removed.
@gaearon
We could also profile Terser a bit and see if there's low hanging fruit.
I made a fairly minimal demo repo of the relevant build scenario. I'm delighted to find that CRA v2 is already configured to use terser-webpack-plugin
. So the build is quick, as expected.
Awesome. No more concern here from me.
Went from 1.1.5 > 2.0.0 and got:
./node_modules/react-event-listener/dist/react-event-listener.cjs.js
Module not found: Can't resolve '@babel/runtime/helpers/builtin/classCallCheck' in 'C:\App\node_modules\react-event-listener\dist'
My package.json: https://gist.github.com/henkvhest/1fdf2d5a65b98ba76379f999f354211d
@henkvhest Thanks, I added this to https://github.com/facebook/create-react-app/issues/5116 which seems similar.
@ArmanNisch Good point. We'll need to do another pass at README and User Guide after releasing.
@gaearon any announcement in changelog and here about: https://github.com/facebook/create-react-app/pull/4169?
@frederikhors Yes, documenting it is in the todos
@Timer I just re-read your comment and realized I'd misunderstood:
Hmm, we can definitely switch back to uglify if it's more performant.
My hope has been to use terser
for better performance and NOT uglify
. I had wrongly assumed that CRA was still using uglify
. I hadn't realized that CRA had already moved to terser
. That wasn't the case last I checked. Anyway, I posted a demo above that demonstrates that, with terser
in CRA 2.0.0
, the relevant scenario builds great. So we're all good here.
I see there's now an inline script added in index.html, which breaks my CSP. Is there a recommended way to deal with this?
@Timer
browserslist is only used for CSS. There were too many edge cases where browser target support for babel did not "just work", unfortunately. This is by no fault browserslist's, it seemed to be more of an issue with preset-env.
Can you show edge case examples? I will try to find people who will fix the source of the problem.
I can help too!
I see there's now an inline script added in index.html, which breaks my CSP. Is there a recommended way to deal with this?
This is interesting, can you tell a bit more? Are all inline scripts disallowed in your environment?
I wasn't allowing any inline scripts previously. Adding 'unsafe-inline' to my script-src gets it working again, but I'd rather be more restrictive.
@ai browserslist is only used for CSS. There were too many edge cases where browser target support for babel did not "just work", unfortunately. This is by no fault browserslist's, it seemed to be more of an issue with
preset-env
.
@Timer just to echo @ai, happy to help prioritize fixing any issues in preset-env.
@caedmon The reason we put it there is because it's better for long term caching. This is a small snippet so it would be a shame to send it as a separate request. And attaching it to some other chunk would constantly invalidate it. I think it's a reasonable compromise. Maybe we can provide an opt-out.
@gaearon I understand the motivation for inlining this code. Would there be a way to configure a nonce to add to the script which could then
be used in the CSP?
Can you raise a separate issue with the proposal please?
Can you raise a separate issue with the proposal please?
tried to run the migration commands but nothing really happened apart of react-scripts was updated to version 2 in my package.json.
@stramel: Are you planning on getting the typescript PR in?
@gnapse: Given thatΒ #4837Β is not yet closed, and not yet even building on CI, I assume the answer is not now. But I hope not too long from nowΒ πππ
TypeScript support #4837 is ready to be merged, in my opinion. Build is now passing.
It didnβt make it into 2.0.0 but hopefully it will be added soon :)
where is my hot reload out of the box?
Removing the mjs
support yields incompatibility with latest versions of graphql-js
library (and iterall
as well), because the lib export itself as module with .mjs
extension. That indirectly affects a couple of Apollo related libraries as well.
A way to workaround this in your projects is to downgrade to version 0.13.0
of graphql
and lock the version of iterall
to 1.1.4
via yarn's resolutions.
it only has hot reload, not hmr :/
hey guys there is another compilation error on react-powerplug
Failed to compile
./node_modules/react-powerplug/dist/react-powerplug.esm.js
Module not found: Can't resolve '@babel/runtime/helpers/builtin/es6/assertThisInitialized' in '.../node_modules/react-powerplug/dist'
also can NODE_ENV
be staging
?
@jt3k
where is my hot reload out of the box?
A few more things need to happen but I think weβll have it by December.
@davidalekna
hey guys there is another compilation error on react-powerplug
Itβs fixed in master. Weβll cut a patch soon.
[email protected]
is out. Everyone, please upgrade your dependencies and see if your issues have been fixes (or if new ones arised)!
Error: Received malformed response from registry for undefined. The registry may be down.
Projects adf$ npx create-react-app@next --scripts-version=@next test-next
npx: installed 63 in 14.711sCreating a new React app in /Users/adf/Projects/test-next.
Installing packages. This might take a couple of minutes.
Installing react, react-dom, and react-scripts...yarn add v1.3.2
info No lockfile found.
[1/4] π Resolving packages...
error Received malformed response from registry for undefined. The registry may be down.
info Visit https://yarnpkg.com/en/docs/cli/add for documentation about this command.
Error: Received malformed response from registry for undefined. The registry may be down.
at /usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:48907:15
at Generator.next ()
at step (/usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:92:30)
at /usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:110:14
at new Promise ()
at new F (/usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:29389:28)
at /usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:89:12
at Function.findVersionInRegistryResponse (/usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:48946:7)
at /usr/local/Cellar/yarn/1.3.2/libexec/lib/cli.js:48963:28
at Generator.next () Aborting installation.
yarnpkg add --exact react react-dom react-scripts@next --cwd /Users/adf/Projects/test-next has failed.Deleting generated file... package.json
Deleting test-next/ from /Users/adf/Projects
Done.
Update your Yarn version and try again.
This is more of an npm issue, but just for awareness:
Running npm upgrade react-scripts@next --save
didn't do anything for me.
I had to run npm install react-scripts@next --save
Odd, I changed the command. Thanks for the heads up!
how about react-scripts-ts ?? is there any upgrade ??
@soufDev We aren't the maintainers of that package. It's maintained by the community. We might add TS support later in 2.x, but not in 2.0.
Just tried v2.0.1, works perfectly. When will v2 be tagged latest
btw?
Thanks.
Today probably.
So... do I have to add babel config or something now, to make it compile node modules properly? I still have it in dependent module itself (used before to build it).
With react-scripts start
I get something like this in dependent module which is a git+https://...
:
Failed to compile.
./node_modules/my-git-node-module/components/ExternalMenuItem.js
Syntax error: Unexpected token (23:4)
21 | const ExternalMenuItem = ({ title, classes }) => {
22 | return (
> 23 | <span className={classes.wrapper} >
| ^
For react-scripts build
getting pretty much the same, JSX is not parsed:
Creating an optimized production build...
Failed to compile.
./node_modules/my-git-node-module/components/HelpIcon.js
Syntax error: Unexpected token (56:6)
54 |
55 | return (
> 56 | <Tooltip
| ^
I do see a bit strange output in the production build. Before the update I had only chunks that I named myself but now some chunks show up labeled from 0 to 7. Anyone else encountered this aswell? It's not blocking me in any way, the application still functions the same as before.
What version did you upgrade from, @henkvhest?
@z-ax
So... do I have to add babel config or something now to make it compile node modules? I have it in dependent module itself (used before to build it).
We only compile valid JavaScript syntax in node_modules
. JSX is not valid JavaScript. You are using JSX there.
The reason we've taken this stance is because compiling non-standard syntax tightly couples libraries to build tools. For example, if JSX changes and Babel 8 comes out with those changes, suddenly all libraries using JSX internally wouldn't work anymore. You can fix your code but fixing dependencies takes a lot more coordinated effort. And people using Babel 7 (in this example) wouldn't appreciate their code breaking either. So every library would be forced to release a new major version, and possibly maintain both for a long time.
It's also hard to draw a line once you allow experimental things. Most people will want to use not just JSX, but also experimental transforms like class properties. Or decorators. Now we have to argue with every library maintainer about which transforms we want to support, and which we don't. But all of these transforms tend to change until standardized. It already happened many times, e.g. Babel 7 changed the semantics of class properties a little bit. It will happen again.
So say Babel 8 comes out with different class properties behavior. Now you have to vet all libraries you depend on to check if they expect old or new behavior. Nobody can upgrade to the next CRA/Babel because they're locked into the experimental syntax their dependencies (including transitive ones) assume. You can see how this exact situation played out with Babel 7 upgrade in the React Native community. It caused months of pain for RN users, and it's still an ongoing problem.
This is why we don't compile non-standard syntax in node_modules
.
What version did you upgrade from, @henkvhest?
From 1.1.5 to 2.0.1
I'm using PreloadWebpackPlugin, after migrate from 6.0.0-next.a671462c to 6.0.1 this error arise:
Syntax error: Unable to tap into the HtmlWebpackPlugin's callbacks. Make sure to list PreloadPlugin at some point after HtmlWebpackPlugin in webpack's plugins array.
This plugin is after HtmlWebpackPlugin:
new PreloadWebpackPlugin({
rel: "prefetch",
include: "allAssets",
})
I can reproduce it in a new project using CRA 2.0:
"html-webpack-plugin": "4.0.0-beta.1",
"preload-webpack-plugin": "3.0.0-beta.2",
"react-dev-utils": "6.0.1",
@djgrant That's not an issue with CRA 2 per se. It's expected that react-dev-utils
changes more often with the needs of the project. You can create a new app and eject it to see how it's wired up. Then you can figure out how to make these two plugins working again.
@gaearon sounds reasonable, but strange same time. We're talking about react scripts, so they are intended to work with React code, which basically has JSX in all of our projects.
We have a situation now, for example, where projects reuse the core library of components, helpers etc. Components are in JSX. As our main apps. As CRA created app example. So, what I was expecting is react-scripts
will compile everything same way, so we won't have any kind of customizations in build process, everything will use same browserslist
etc.
Is there an option to "turn on" JSX processing in node modules?
The problem isn't with just JSX, it's with all the other experimental transforms. But JSX is a part of it too.
We're talking about react scripts, so they are intended to work with React code, which basically has JSX in all of our projects.
And your application code builds just fine. We're only talking about third-party dependencies.
We have a situation now, for example, where projects reuse the core library of components, helpers etc. Components are in JSX. As our main apps. As CRA created app example. So, what I was expecting is react-scripts will compile everything same way, so we won't have any kind of customizations in build process, everything will use same browserslist etc.
I understand this very well. Monorepo support was supposed to help with this but we removed it from 2.0 because it was half-baked. We want to allow something like this later, but we need to figure out for it to be safe and opt-in without creating problems for the ecosystem.
Syntax error: Unable to tap into the HtmlWebpackPlugin's callbacks
The upcoming html-webpack-plugin v4 (of which 4.0.0-beta.1
is included in CRA 2) has changed the name of several hooks, meaning that many plugins will need updates to remain compatible:
https://github.com/jantimon/html-webpack-plugin/pull/953#issue-189369685
To get the ball rolling for this case I've filed GoogleChromeLabs/preload-webpack-plugin#79.
@gaearon so, now there is no option to have the same processing for modules as for the main app? Or at least specify additional pre-processing? Sounds SO weird to me.
@z-ax No, there's no such option. I don't know what to make of your "Sounds SO weird" comment to be honest. You're welcome to write up a proposal and/or implement it, I guess? This is an open source project.
@gaearon that was just my personal expectation, when it was announced that node modules will be built too. I thought: "finally, the same build for all the code".
Let's start with a proposal, I'd be happy to contribute if it will be accepted (maybe I don't see the bigger picture now). Just fire a new ticket?
@z-ax Yes, new ticket is fine! I can explain our constraints in more detail there if you'd like, and why previous attempt didn't quite work out. Don't get me wrong β I'd love to support what you're asking for β but "building everything in the same way" has already proven to be a disaster in RN ecosystem and I don't want to repeat their mistakes.
@gaearon sure, I get it as well. Especially taking into consideration that my expertise might be way too narrow in this question. Added a proposal, let's continue there :)
I did a livestream to show how to use the babel-plugin-macros support: https://www.youtube.com/watch?v=1ERAJG9ILhk&list=PLV5CVI1eNcJgCrPH_e6d57KRUTiDZgs0u
It works pretty well. There were a few hiccups, but I don't think the issue is CRA's. So π from me!
What happened to the CSS Modules support? I see it listed in the additions to RS.
@manuelro
What happened to the CSS Modules support? I see it listed in the additions to RS.
Nothing happened to it. Are you seeing any problems?
Is graphql-loader included by default in v2?
Nevermind - just saw #5076 so looks like a babel macro will do the job π
@manuelro
What happened to the CSS Modules support? I see it listed in the additions to RS.
Nothing happened to it. Are you seeing any problems?
Never mind, already saw this: https://github.com/facebook/create-react-app/pull/2285 - Lovely job as usual! :)
just upgraded my c-r-a v1 app to v2, instructions were great!
one small piece of feedback. in the "advanced proxy configuration" instructions above, it tells you how to switch to http-proxy-middleware
. Probably worth mentioning that once src/setupProxy.js
is created, you can delete the proxy
field in package.json
, and furthermore you dont have to import src/setupProxy.js
anywhere as it is a "magic file". i prefer that every piece of magic is explained.
Please send a PR, @sw-yx !
Upgrading an existing project via the yarn instructions fails on Node 10:
[1/4] π Resolving packages...
[2/4] π Fetching packages...
[---------------------------------------------------------------------------------------------] 0/1605(node:51195) [DEP0005] DeprecationWarning: Buffer() is deprecated due to security and usability issues. Please use the Buffer.alloc(), Buffer.allocUnsafe(), or Buffer.from() methods instead.
error [email protected]: The engine "node" is incompatible with this module. Expected version ">=4 <=9".
error Found incompatible module
node -v
v10.11.0
You can run yarn with --ignore-engines
to work around this. Weird though.
I hope you will check #5164 I attached earlier, because when build/start works but tests fail to parse same files it is inconsistency.
Maybe a stupid question, but why you don't add the HMR or module.hot.accept()
in index.js?
To make a DX similar to the Vue?
Just a followup: --ignore-engines
worked! Maybe this is MacOS-specific?
β john@Johns-MBP ξ° ~/src/cra-2 > yarn why upath
yarn why v1.10.1
[1/4] π€ Why do we have the module "upath"...?
[2/4] π Initialising dependency graph...
[3/4] π Finding dependency...
[4/4] π‘ Calculating file sizes...
=> Found "[email protected]"
info Reasons this module exists
- "react-scripts#webpack-dev-server#chokidar" depends on it
- Hoisted from "react-scripts#webpack-dev-server#chokidar#upath"
info Disk size without dependencies: "56KB"
info Disk size with unique dependencies: "56KB"
info Disk size with transitive dependencies: "56KB"
info Number of shared dependencies: 0
=> Found "watchpack#[email protected]"
info Reasons this module exists
- "react-scripts#webpack#watchpack#chokidar" depends on it
- Hoisted from "react-scripts#webpack#watchpack#chokidar#upath"
info Disk size without dependencies: "56KB"
info Disk size with unique dependencies: "56KB"
info Disk size with transitive dependencies: "56KB"
info Number of shared dependencies: 0
@yuritoledo
Maybe a stupid question, but why you don't add the HMR or module.hot.accept() in index.js?
To make a DX similar to the Vue?
You can add it yourself but we're not super happy with how it works. We are planning proper support for hot reloading later this year.
@z-ax
I hope you will check #5164 I attached earlier, because when build/start works but tests fail to parse same files it is inconsistency.
Could you please attach a reproducing project there? Would help determine if it's a regression or some intentional change.
Not sure if this falls under create-react-app issue.
Upgrading from v1.1.5 to v2 using
npm install react-scripts@next --save
for existing (non-ejected) create-react-app:
https://github.com/cereallarceny/cra-ssr/
https://medium.com/@cereallarceny/server-side-rendering-in-create-react-app-with-all-the-goodies-without-ejecting-4c889d7db25e
This app has ssr in the server folder:
server/index.js
that contains:
....
require('babel-register')({
ignore: /\/(build|node_modules)\//,
presets: ['env', 'react-app'],
plugins: [
'syntax-dynamic-import',
'dynamic-import-node',
'react-loadable/babel'
]
});
and package.json:
"scripts": {
"start": "react-scripts start",
"build": "GENERATE_SOURCEMAP=false react-scripts build",
"test": "react-scripts test --env=jsdom",
"precommit": "lint-staged",
"serve": "NODE_ENV=production node ./server/index.js",
"eject": "react-scripts eject"
After installing missing dependencies:
yarn add query-string
yarn add babel-plugin-syntax-dynamic-import
yarn add babel-plugin-dynamic-import-node
yarn build is successful
But
yarn serve
throws error:
Error: Couldn't find preset "env" relative to directory .....
If the 'env' is removed
from
presets: ['env', 'react-app'],
yarn serve
throws different error
Error: Requires Babel "^7.0.0-0", but was loaded with "6.26.3". If you are sure you have a compatible version of @babel/core, it is likely that something in your build process is loading the wrong version. Inspect the stack trace of this error to look for the first entry that doesn't mention "@babel/core" or "babel-core" to see what is calling Babel. (While processing preset: .....
Nope! That's not an issue with Create React App.
Note, we don't support SSR -- please ask the original source for an updated example.
I tried upgrading an existing cra app (created recently) to v2 and it worked out of box for building.
However, my test command fails with
FAIL src/App.test.js
β Test suite failed to run
ReferenceError: [BABEL] /Users/yuan/personal/erqiu-js-lessons/src/App.test.js: Unknown option: base.configFile. Check out http://babeljs.io/docs/usage/options/ for more information about options.
A common cause of this error is the presence of a configuration options object without the corresponding preset name. Example:
Invalid:
`{ presets: [{option: value}] }`
Valid:
`{ presets: [['presetName', {option: value}]] }`
For more detailed information on preset configuration, please see https://babeljs.io/docs/en/plugins#pluginpresets-options.
at Logger.error (node_modules/babel-core/lib/transformation/file/logger.js:41:11)
at OptionManager.mergeOptions (node_modules/babel-core/lib/transformation/file/options/option-manager.js:226:20)
at OptionManager.init (node_modules/babel-core/lib/transformation/file/options/option-manager.js:368:12)
at File.initOptions (node_modules/babel-core/lib/transformation/file/index.js:212:65)
at new File (node_modules/babel-core/lib/transformation/file/index.js:135:24)
at Pipeline.transform (node_modules/babel-core/lib/transformation/pipeline.js:46:16)
I saw the upgrade instruction, so changed "react-scripts test --env=jsdom" to "react-scripts test", but still no luck.
any clues?
I am guessing it may be related to one of the modules I am using, they are here:
"dependencies": {
"emotion": "^9.2.10",
"react": "^16.5.2",
"react-dom": "^16.5.2",
"react-emotion": "^9.2.10",
"react-flip-toolkit": "^5.0.1",
"react-scripts": "^2.0.1"
},
since building the app works, I guess this might happen if building and testing are using different mechanism to transpile, is that the case?
I'll try to look into my dependencies. I'll get back if I got sth.
@Bobgy Do you use anything that might be messing with our configs? Like rewired
or something similar. Otherwise a minimal reproducing project would be very helpful.
Another thing worth trying is to delete node_modules
and re-run npm (or Yarn).
@gaearon oops, I think there were a few things going wrong, so I couldn't reproduce the error now.
In some terminals, I forgot to switch from node 6 to node 10. There might have been modules I installed with npm 3 when I reported the issue. Then I switched to node 10, removed node_modules completely (I must do this) and reran the test, it's all working now.
Sorry for the confusion.
Hi, we have tried to upgrade to the new version CRA2, but was impossible... we have found errors with decorators (we use MobX), eslint issues and react-toolbox. Previously we have been using react-rewired... We will read carefully the documentation again. We have solved many issues (like eslint dependecies version, removing the node_modules folder).
I have some questions... can we use CRA v2 with decorators without react-rewired? Thanks.
@chemitaxis you can use this https://github.com/arackaf/customize-cra.
yo try make it less configurable and more dogmatic
Hi, we have tried to upgrade to the new version CRA2, but was impossible... we have found errors with decorators (we use MobX), eslint issues and react-toolbox. Previously we have been using react-rewired... We will read carefully the documentation again. We have solved many issues (like eslint dependecies version, removing the node_modules folder).
If you open react-app-rewired
README and read the first sentence, it says:
β οΈ β οΈThis repo doesn't support CRA 2.0 see: https://github.com/timarney/react-app-rewired/issues/162#issuecomment-417872507
Additionally, it says:
By doing this you're breaking the "guarantees" that CRA provides. That is to say you now "own" the configs. No support will be provided. Proceed with caution.
Therefore you shouldn't be surprised that following migration instructions doesn't work for you. That's what you agreed to when you started using react-app-rewired
.
can we use CRA v2 with decorators without react-rewired? Thanks.
Indeed you can try this although just like react-app-rewired
, we don't intend to support it ourselves. So it may break in other ways on any upgrade.
The reason we don't allow using decorators is because they're an unstable feature, and in fact it has already just changed its semantics. This means your old code using decorators won't work with the new syntax β unless all the libraries you depend on figure out a way to support both syntaxes. Additionally, there are _more_ syntax changes planned for decorators. This is why we'll keep them disabled.
What's the advised way to import Markdown files into CRA? Before I used react-app-rewired
and made it use the @mapbox/jsxtreme-markdown-loader
-loader so that I could generate some semi dynamic markdown files. Maybe I should move to `customize-cra?
Or could I use babel-macros
for this instead? Basically I am having a markdown file which becomes a React component and can be used like e.g. <BusinessAgreement {...profileData} />
and then in the markdown I would be able to {{ props.profile.fullName || 'Not provided' }}
@weyert Yeah babel-macros
should work for this. See https://github.com/facebook/create-react-app/issues/5149#issuecomment-425396995.
Hi everyone! We just released [email protected]
. Please upgrade your apps and ensure everything is still working.
So what about TypeScript built-in support?
Thanks @gaearon and sorry... my mistake. We are replacing all our decorators (@observers). I will be back and I will give you feedback...
@borisowsky We didn't say TypeScript would be coming in 2.0 anywhere. That said it's likely we'll add something in 2.x.
Upgrading an app created with 1.1.3, no issues when upgrading react-scripts
but I'm having trouble trying to install the polyfills:
$ yarn add react-app-polyfill
yarn add v1.9.4
warning package-lock.json found. Your project contains lock files generated by tools other than Yarn. It is advised not to mix package managers in order to avoid resolution inconsistencies caused by unsynchronized lock files. To clear this warning, remove package-lock.json.
[1/5] π Validating package.json...
[2/5] π Resolving packages...
[3/5] π Fetching packages...
[4/5] π Linking dependencies...
warning " > @storybook/[email protected]" has incorrect peer dependency "@storybook/[email protected]".
warning "@storybook/addon-storyshots > [email protected]" has unmet peer dependency "jest@>=20 <=23".
warning "@storybook/addon-storyshots > [email protected]" has unmet peer dependency "jest@*".
<--- Last few GCs --->
[83663:0x102804400] 183430 ms: Mark-sweep 2364.2 (2453.2) -> 2360.9 (2454.2) MB, 443.8 / 0.0 ms allocation failure GC in old space requested
[83663:0x102804400] 183885 ms: Mark-sweep 2360.9 (2454.2) -> 2360.8 (2421.7) MB, 455.1 / 0.0 ms last resort GC in old space requested
[83663:0x102804400] 184336 ms: Mark-sweep 2360.8 (2421.7) -> 2360.8 (2421.2) MB, 450.3 / 0.0 ms last resort GC in old space requested
<--- JS stacktrace --->
==== JS stack trace =========================================
Security context: 0x13c91c8a5879 <JSObject>
1: set(this=0x13c9f54a9ac9 <Map map = 0x13c90e5048d9>,0x13c90c11f7b1 <Very long string[2763]>,0x13c90c120d61 <HoistManifest map = 0x13c99babdfb1>)
2: taintKey [/Users/pimlottc/.nvm/versions/node/v8.11.3/lib/node_modules/yarn/lib/cli.js:~85401] [pc=0x135cab899916](this=0x13c992f49cf1 <PackageHoister map = 0x13c99baad1d9>,key=0x13c90c11f7b1 <Very long string[2763]>,info=0x13c90c120d61 <Hoi...
FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory
1: node::Abort() [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
2: node::FatalException(v8::Isolate*, v8::Local<v8::Value>, v8::Local<v8::Message>) [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
3: v8::internal::V8::FatalProcessOutOfMemory(char const*, bool) [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
4: v8::internal::Factory::NewFixedArray(int, v8::internal::PretenureFlag) [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
5: v8::internal::OrderedHashTable<v8::internal::OrderedHashMap, 2>::Rehash(v8::internal::Handle<v8::internal::OrderedHashMap>, int) [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
6: v8::internal::Runtime_MapGrow(int, v8::internal::Object**, v8::internal::Isolate*) [/Users/pimlottc/.nvm/versions/node/v8.11.3/bin/node]
7: 0x135cab5842fd
Abort trap: 6
Sorry, that sounds like a Yarn failure so we can't help with it.
@gaearon okay, I mention it though because I didn't have this issue before I upgraded react-scripts
.
Looks like there is a new release of [email protected] that CRA is complaining about if you have eslint installed local.
I mean, in general we never supported installing eslint
at top level of your project.
I mean, in general we never supported installing eslint at top level of your project.
I know this is the official stance and this discussion should take place elsewhere but I think many people who are using CRA in a production / semi-production setup use eslint
to do more than in editor linting tasks.
I understand where you're coming from β I'm not saying we're opposed on principle but I'm saying that it has always caused hard-to-debug issues like this due to how ESLint doesn't allow presets to encapsulate their plugins. ESLint plans to fix this in ESLint 5 so that will solve the issue permanently. In the meantime, we want to warn our users that when they do something like this, our setup can break.
Again, you can ignore our warning, just as the warning says. Or maybe we're talking about different things. Did you notice the warning provides instructions for how to turn it off at the bottom?
I've followed the instructions from the proxy migrations but they don't work for me, i've installed the
'http-proxy-middleware' package and created the 'setupProxy.js' file inside the 'src' folder in my client but
it's not working, any idea?
@R4z1ell Please file a new issue.
Most helpful comment
Are you planning on getting the typescript PR in or will that come in a minor update post 2.0 release?