Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

CRA + React Leaflet: failed to compile

I've just started a brand new project using create-react-app and set up react-leaflet as their documentation recommends here.

I am trying to use this example to check if it's all working good but then I'm receiving the following error:

./node_modules/@react-leaflet/core/esm/path.js 10:41
Module parse failed: Unexpected token (10:41)
File was processed with these loaders:
 * ./node_modules/react-scripts/node_modules/babel-loader/lib/index.js
You may need an additional loader to handle the result of these loaders.
|   useEffect(function updatePathOptions() {
|     if (props.pathOptions !== optionsRef.current) {
>       const options = props.pathOptions ?? {};
|       element.instance.setStyle(options);
|       optionsRef.current = options;

Looks like react-scripts can't handle react-leaflet files. Can someone helps me to understand why it's happening and how do I fix it ?

like image 974
Victor Seara Avatar asked May 15 '21 23:05

Victor Seara


1 Answers

After reading about it on all blogs , I have concluded that : It's because of the new version of the react-leaflet. I faced the same problem and here's how I got rid of the error:

Open your package.json file

 "browserslist": {
 "production": [
  ">0.2%",
  "not dead",
  "not op_mini all"
],
"development": [
  "last 1 chrome version",
  "last 1 firefox version",
  "last 1 safari version"
]
},

Replace it with following lines :

"browserslist": [
">0.2%",
"not dead",
"not op_mini all"
],
  • Now Delete node_modeules/.cache folder

  • npm install

  • npm start

Another method is to just add these lines in your package.json file:

"react-leaflet": ">=3.1.0 <3.2.0 || ^3.2.1",
"@react-leaflet/core": ">=1.0.0 <1.1.0 || ^1.1.1"
  • This will skip the newly released version of the @react-leaflet/core package
like image 193
Vidhu Verma Avatar answered Sep 19 '22 07:09

Vidhu Verma