Webpack Module Warning: Failed to parse source map from "data" URL
Asked Answered
C

11

41

I'm receiving a bummer warning and have been unable to find an available solution:

WARNING in ../lensing/dist/main.js
Module Warning (from ./node_modules/source-map-loader/dist/cjs.js):
Failed to parse source map from "data" URL: data:application/json;charset=utf-8;base64,eyJ2ZXJza [...]

My webpack.config.js looks like (setup for npm module):

module.exports = {
    entry: './src/index.js',
    output: {
        filename: 'main.js',
        path: path.resolve(__dirname, 'dist'),
        library: 'lensing',
        libraryTarget: 'umd',
        umdNamedDefine: true
    },
    module: {
        rules: [
            {
                test: /\.m?js$/,
                exclude: /(node_modules|bower_components)/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['@babel/preset-env'],
                        plugins: [
                            '@babel/plugin-proposal-class-properties'
                        ]
                    }
                }
            },
            {
                test: /\.js$/,
                enforce: 'pre',
                use: ['source-map-loader'],
            },
            {
                test: /\.(png|jpg|gif|svg)$/i,
                use: [
                    {
                        loader: 'url-loader',
                        options: {
                            limit: 8192,
                        },
                    },
                ],
            }
        ]
    },
    stats: {
        warningsFilter: [/Failed to parse source map/],
    },
};

I've been surprised not to find much else on this specific issue and am worried that I've missed something that is typically straightforward. I am happy to include any other code snippets that might be helpful but am hoping that the error code might be a strong indiator.

Any advice would be warmly welcomed!

EDIT - more context:

Version: webpack 4.43.0
Time: 6561ms
Built at: 07/31/2020 11:20:55 AM
                               Asset       Size  Chunks             Chunk Names
aafa1b05e4b76ffd04c1fe92edbf15f2.svg  654 bytes          [emitted]  
                             main.js    3.6 MiB    main  [emitted]  main
Entrypoint main = main.js
[0] multi (webpack)-dev-server/client?http://localhost:9000 ./src/index.js 40 bytes {main} [built]
[../lensing/dist/main.js] 2.46 MiB {main} [built] [1 warning]
[./node_modules/openseadragon/build/openseadragon/openseadragon.js] 674 KiB {main} [built]
[./node_modules/webpack-dev-server/client/index.js?http://localhost:9000] (webpack)-dev-server/client?http://localhost:9000 4.29 KiB {main} [built]
[./node_modules/webpack-dev-server/client/overlay.js] (webpack)-dev-server/client/overlay.js 3.51 KiB {main} [built]
[./node_modules/webpack-dev-server/client/socket.js] (webpack)-dev-server/client/socket.js 1.53 KiB {main} [built]
[./node_modules/webpack-dev-server/client/utils/createSocketUrl.js] (webpack)-dev-server/client/utils/createSocketUrl.js 2.91 KiB {main} [built]
[./node_modules/webpack-dev-server/client/utils/log.js] (webpack)-dev-server/client/utils/log.js 964 bytes {main} [built]
[./node_modules/webpack-dev-server/client/utils/reloadApp.js] (webpack)-dev-server/client/utils/reloadApp.js 1.59 KiB {main} [built]
[./node_modules/webpack-dev-server/client/utils/sendMessage.js] (webpack)-dev-server/client/utils/sendMessage.js 402 bytes {main} [built]
[./node_modules/webpack-dev-server/node_modules/strip-ansi/index.js] (webpack)-dev-server/node_modules/strip-ansi/index.js 162 bytes {main} [built]
[./node_modules/webpack/hot sync ^\.\/log$] (webpack)/hot sync nonrecursive ^\.\/log$ 170 bytes {main} [built]
[./src/PIA23533_index32.csv] 622 bytes {main} [built]
[./src/index.css] 519 bytes {main} [built]
[./src/index.js] 1.69 KiB {main} [built]
    + 27 hidden modules

WARNING in ../lensing/dist/main.js
Module Warning (from ./node_modules/source-map-loader/dist/cjs.js):
Failed to parse source map from "data" URL: data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/viewfinder.js.js","sources":["webpack://lensing/./src/viewfinder.js?b5ef"],"sourcesContent":["import * as d3 from 'd3';\n\n/**\n * @class Viewfinder\n */\nexport default class Viewfinder {\n\n    // Class refs\n    lensing = null;\n\n    // Data\n    data = null;\n    on = false;\n\n    // Elements\n    els = {\n        dataPointG: null,\n        g: null,\n        radialG: null,\n        svg: null,\n        boxG: null\n    };\n\n    // Configs\n    configs = {\n        boxW: 150,\n        boxH: 50,\n        deg: 0,\n        extend: 200,\n        gMargin: {top: 0, left: 0, right: 0, bottom: 0},\n        gH: 0,\n        gW: 0,\n        h: 0,\n        r: 0,\n        rPointer: 0,\n        rPointerExt: 25,\n        w: 0,\n    };\n\n    // Tools - TODO add boxScale to trace perimeter\n    tools = {\n        coordScale: d3.scaleLinear()\n            .domain([0, 360])\n            .range([Math.PI, -Math.PI]),\n        lineMaker: d3.line(),\n        xScale: d3.scaleLinear(),\n        yScale: d3.scaleLinear()\n    }\n\n    /*\n    Constructor\n     */\n    constructor(_lensing) {\n        // Fields\n        this.lensing = _lensing;\n\n        // Init\n        this.init();\n    }\n\n    /**\n     * 1.\n     * @function init\n     *\n     */\n    init() {\n        // Define this\n        const vis = this;\n\n        // Build svg, g\n        vis.els.svg = d3.select(vis.lensing.overlay.container)\n            .append('svg');\n        vis.els.g = vis.els.svg.append('g')\n            .attr('class', 'viewfinder_g')\n            .style('transform', `translate(${vis.configs.gMargin.top}px, ${vis.configs.gMargin.left}px)`);\n\n        // Attach component g's\n        vis.els.radialG = vis.els.g.append('g')\n            .attr('class', 'viewfinder_radial_g');\n        vis.els.dataPointG = vis.els.radialG.append('g')\n            .attr('class', 'viewfinder_data_point_g');\n        vis.els.dataPointG.append('path')\n            .attr('fill', 'none')\n            .attr('stroke', 'rgba(255, 255, 255, 1)')\n            .style('transform', 'translate3d(0, 0, 0)');\n        vis.els.boxG = vis.els.dataPointG.append('g')\n            .attr('class', 'viewfinder_box_g')\n            .style('transform', 'translate3d(0, 0, 0)')\n            .style('visibility', 'hidden');\n        vis.els.boxG.append('rect')\n            .attr('width', vis.configs.boxW)\n            .attr('height', vis.configs.boxH)\n            .attr('fill', 'none')\n            .attr('stroke', 'rgba(255, 255, 255, 1)')\n            .attr('stroke-width', '0.5px');\n        vis.els.boxG.append('text')\n            .attr('class', 'viewfinder_box_text viewfinder_box_text_a')\n            .attr('fill', 'white')\n            .attr('x', `${vis.configs.boxW / 2}px`)\n            .attr('y', `${Math.round(vis.configs.boxH / 3)}px`)\n            .attr('text-anchor', 'middle')\n            .attr('alignment-baseline', 'middle')\n            .style('font-family', 'sans-serif')\n            .style('font-size', '12px')\n            .style('font-weight', 'lighter');\n        vis.els.boxG.append('text')\n            .attr('class', 'viewfinder_box_text viewfinder_box_text_b')\n            .attr('fill', 'white')\n            .attr('x', `${vis.configs.boxW / 2}px`)\n            .attr('y', `${Math.round(vis.configs.boxH * 2 / 3)}px`)\n            .attr('text-anchor', 'middle')\n            .attr('alignment-baseline', 'middle')\n            .style('font-family', 'sans-serif')\n            .style('font-size', '11px')\n            .style('font-style', 'italic')\n            .style('font-weight', 'lighter');\n\n    }\n\n    /**\n     * @function wrangle\n     *\n     */\n    wrangle() {\n        // Define this\n        const vis = this;\n\n        // Update data\n        vis.data = this.lensing.configs.pxData;\n\n        // Update configs\n        vis.configs.r = vis.lensing.configs.rad / vis.lensing.configs.pxRatio;\n        vis.configs.rPointer = vis.configs.r + vis.configs.rPointerExt;\n        vis.configs.w = vis.configs.h = (vis.configs.r + vis.configs.extend) * 2;\n        vis.configs.gW = vis.configs.w - (vis.configs.gMargin.right + vis.configs.gMargin.left);\n        vis.configs.gH = vis.configs.h - (vis.configs.gMargin.top + vis.configs.gMargin.bottom);\n\n        // Check coordinate position\n        const x = this.lensing.configs.pos[0] / vis.lensing.configs.pxRatio - this.lensing.viewer.canvas.clientWidth / 2;\n        const y = this.lensing.configs.pos[1] / vis.lensing.configs.pxRatio - this.lensing.viewer.canvas.clientHeight / 2;\n        vis.deg = Math.atan2(y, x) * (180 / Math.PI);\n\n        // Update tools\n        vis.tools.xScale\n            .domain([-vis.configs.rPointer, vis.configs.rPointer])\n            .range([-vis.configs.boxW, 0]);\n        vis.tools.yScale\n            .domain([-vis.configs.rPointer, vis.configs.rPointer])\n            .range([-vis.configs.boxH, 0]);\n\n        // Render\n        vis.render();\n    }\n\n    /**\n     * @function render\n     *\n     */\n    render() {\n        // Define this\n        const vis = this;\n\n        if (vis.on) {\n\n            // Update svg, g\n            vis.els.svg.attr('width', vis.configs.w)\n                .attr('height', vis.configs.h)\n                .attr('style', `position: absolute; left: ${-vis.configs.extend}px; top: ${-vis.configs.extend}px;`)\n\n            // Update radialG\n            vis.els.radialG.style('transform', `translate(${vis.configs.gW / 2}px, ${vis.configs.gH / 2}px)`)\n\n            // Update dataPointG\n            vis.els.dataPointG\n                .datum(vis.data)\n                .each(function (d) {\n                    const g = d3.select(this);\n\n                    // Pointer coords\n                    const pCoords = getCoords(vis.configs.rPointer, vis.deg - 90);\n                    const addX = Math.round(vis.tools.xScale(pCoords[0]));\n                    const addY = Math.round(vis.tools.yScale(pCoords[1]));\n\n                    // Update path\n                    g.select('path')\n                        .attr('d', vis.tools.lineMaker([[0, 0], pCoords]));\n\n                    // Update boxG visibility, pos\n                    vis.els.boxG.style('visibility', 'visible');\n                    vis.els.boxG.style('transform', `translate(${pCoords[0] + addX}px, ${pCoords[1] + addY}px)`);\n                });\n\n            /* getCoords */\n            function getCoords(r, i) {\n                const x = Math.round(r * Math.sin(vis.tools.coordScale(i)));\n                const y = Math.round(r * Math.cos(vis.tools.coordScale(i)));\n                return [x, y];\n            }\n        } else {\n\n            // Hide\n            vis.els.boxG.style('visibility', 'hidden');\n        }\n\n    }\n\n    /**\n     * @function update_box_text\n     * Updates the text from data\n     *\n     * @param {Object} d\n     *\n     */\n    update_box_test(d) {\n        // Define this\n        const vis = this;\n\n        // Update\n        vis.els.boxG.select('.viewfinder_box_text_a')\n            .text(`Color Index #${d.index}`);\n        vis.els.boxG.select('.viewfinder_box_text_b')\n            .text(`rgb(${d.r}, ${d.g}, ${d.b})`);\n    }\n\n\n}"],"mappings":";;;;;;;;;;;AAAA;AAEA;;;;AAGA;AAEA;AAGA;AAIA;AASA;AAgBA;AACA;AASA;;;AAGA;AAAA;AACA;AADA;AACA;AADA;AACA;AADA;AACA;AADA;AApCA;AACA;AACA;AACA;AACA;AALA;AACA;AAoCA;AA3BA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;AACA;AA2BA;AAXA;AAGA;AACA;AACA;AANA;AACA;AAYA;AACA;AACA;AAEA;AACA;AAEA;;;;;;;;;AAKA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAIA;AAEA;AAEA;AAIA;AAIA;AAMA;AAUA;AAYA;AAEA;;;;;;;AAIA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAGA;AACA;AAIA;AACA;AAEA;;;;;;;AAIA;AACA;AACA;AACA;AACA;AA8BA;AA9BA;AAgCA;AACA;AACA;AACA;AACA;AAlCA;AACA;AACA;AAIA;AACA;AAEA;AAGA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AAQA;AAEA;AACA;AACA;AAEA;AAEA;;;;;;;;;;AAOA;AACA;AACA;AACA;AAEA;AAEA;AAEA;;;;;;","sourceRoot":""}\n//#
 @ ./src/index.js 3:0-29 65:19-30
Communicable answered 31/7, 2020 at 16:38 Comment(6)
when does this error happen? browser or on build?Plaster
Thanks @henokg - seeing it in both places (w webpack dev server and in Chrome console). Any thoughts? EDIT - more specifically it is linked (w npm link) to a demo using webpack (so I am seeing the error in the demo).Communicable
can you post more of the error? can't seem to make anything of this alone and can you post it from the dev server console and not the browser one\Plaster
Thanks - I've just done. As a sort of fix I removed the source-map-parser and the warning disappeared. Is it possible this issue happened because a webpack watch package was linked to a webpack watch application?Communicable
good thing it worked, i thought the issue was related to performance or size limitationPlaster
Thanks @henokg for willingness to help - be blessed!Communicable
K
42

If you're experiencing this issue with react-scripts/cra version 5.0.0. You'll need to add the following to your .env file

NOTE: this is not a fix. You are suppressing the source map warnings, but it may get you from seeing those warnings since all other solutions have not worked.

GENERATE_SOURCEMAP=false

or you can update your script to

"start": "GENERATE_SOURCEMAP=false react-scripts start",

Note: this is a temporary patch until 5.0.1 is released. See create-react-app repo pull request Update: 5.0.1 was release on April 2022. Changelog. The update did not fix this issue. Not sure when that will be 🤷🏾‍♂️

Kunlun answered 3/2, 2022 at 17:40 Comment(2)
uhm source maps have a purpose and not generating them will break many development flowsPictish
Well aware of it but instead of getting 200+ warnings I can't fix at this moment this is a fair alternate patch until 5.0.1 gets releaseKunlun
S
32

A better way. The following keeps source maps, and just removes the spam warning. From the docs

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        enforce: "pre",
        use: ["source-map-loader"],
      },
    ],
  },
  ignoreWarnings: [/Failed to parse source map/],
};
Saucedo answered 24/6, 2021 at 15:45 Comment(0)
E
13

I have the same problem.

This isn't a solution, but a better workaround than the other "answer":

change your webpack.config.js module.rules setting for source-map-loader to this:

//module.rules:[
            {
                    test: /\.js$/,
                    enforce: 'pre',
                    use: [
                        {
                            //needed to chain sourcemaps.  see: https://webpack.js.org/loaders/source-map-loader/
                            loader: 'source-map-loader',
                            options: {

                                filterSourceMappingUrl: (url, resourcePath) => {
                                    //  console.log({ url, resourcePath }) example:
                                    // {
                                    //  url: 'index.js.map',
                                    //  resourcePath: '/repos/xlib-wsl/common/temp/node_modules/.pnpm/[email protected]/node_modules/https-proxy-agent/dist/index.js'
                                    // }

                                    if (/.*\/node_modules\/.*/.test(resourcePath)) {
                                        return false
                                    }
                                    return true
                                }

                            }
                        }],
                },

That is, don't load sourcemaps for your node_module dependencies.

Ernst answered 23/9, 2020 at 19:59 Comment(2)
Why is it better than using the exclude property? Seems to do the same through more complex JS code.Atworth
The selected answer clearly stated, "if you are using react-scripts/cra" which implies you cannot access the webpack config.Mcconnell
C
11
{
    test: [/\.js?$/, /\.ts?$/, /\.jsx?$/, /\.tsx?$/],
    enforce: 'pre',
    exclude: /node_modules/,
    use: ['source-map-loader'],
},

include this into config file and download the source-map-loader as a dev-dependency

Coveney answered 14/5, 2021 at 20:53 Comment(1)
Excluding node_modules from source maps is indeed a workaround (if you're not interested in debugging down to the libs), but source-map-loader can only handle js files.Atworth
B
8

Adding to the solutions above, when using create-react-app having added react-app-rewired and customize-cra you can also get rid of the source map warnings updating config-overrides.js and setting ignoreWarnings

const { override } = require("customize-cra");

const ignoreWarnings = value => config => {
  config.ignoreWarnings = value;
  return config;
};

module.exports = override(
  ignoreWarnings([/Failed to parse source map/])
);
Buggery answered 16/1, 2022 at 2:59 Comment(0)
J
8

Extending FrozenKiwi's answer for Craco

// craco.config.js
module.exports = {
    reactScriptsVersion: "react-scripts" /* (default value) */,
    webpack: {
        mode: 'extends',
        configure: {
            module: {
                rules: [
                    {
                        test: /\.js$/,
                        enforce: "pre",
                        use: ["source-map-loader"],
                    },
                ],
            },
            ignoreWarnings: [/Failed to parse source map/],
        },
    },
}
Jamila answered 8/7, 2022 at 11:57 Comment(1)
Thanks for this! This works and also seems to speed up the rebuildingAbbreviation
E
1

The best solution is to create a 'config-overrides.js' file on your root directory.the add below code:

const webpack = require('webpack');

module.exports = function override(config) {

    config.ignoreWarnings = [/Failed to parse source map/];
    const fallback = config.resolve.fallback || {};
    Object.assign(fallback, {
        "crypto": require.resolve("crypto-browserify"),
        "stream": require.resolve("stream-browserify"),
        "assert": require.resolve("assert"),
        "http": require.resolve("stream-http"),
        "https": require.resolve("https-browserify"),
        "os": require.resolve("os-browserify"),
        "url": require.resolve("url")
    })

    config.resolve.fallback = fallback;
    config.plugins = (config.plugins || []).concat([
        new webpack.ProvidePlugin({
            process: 'process/browser',
            Buffer: ['buffer', 'Buffer']
        })
    ])
    return config;
}

after that install dev npm packages for webpack

npm i -D crypto-browserify stream-browserify assert stream-http https-browserify os-browserify url

and finally you need to change your package.json start and build

 "scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
  },
Exhibitionist answered 24/5, 2023 at 9:33 Comment(0)
C
0

Why the warning?

I was running webpack on an npm package in watch mode and testing it on a demo app that was also using webpack in watch mode by using npm link [package-name].

Workaround for dev:

Remove source-map-loader from the webpack.config.js in your demo.

Communicable answered 31/7, 2020 at 18:48 Comment(0)
P
0

I was having the same warning in the console when working on a project created with create-react-app and the following solution worked for me.

I replaced the @remix-run folder in node_modules with the same folder from a different CRA project which was running without this warning and the warning disappeared.

Pemphigus answered 3/2, 2023 at 1:26 Comment(0)
C
-1

faced same issue, i think your api is not being called becuase of cors issue

Consecrate answered 16/11, 2022 at 20:46 Comment(1)
As it’s currently written, your answer is unclear. Please edit to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers in the help center.Kremenchug
T
-3

This solution helps me in create-react-app.

You can add this fix by editing the file node_modules/react-scripts/config/webpack.config.js, and pasting this after the line performance: false,

ignoreWarnings: [
  // Ignore warnings raised by source-map-loader.
  // some third party packages may ship miss-configured sourcemaps, that interrupts the build
  // See: https://github.com/facebook/create-react-app/discussions/11278#discussioncomment-1780169
  /**
   *
   * @param {import('webpack').WebpackError} warning
   * @returns {boolean}
   */
  function ignoreSourcemapsloaderWarnings(warning) {
    return (
      warning.module &&
      warning.module.resource.includes('node_modules') &&
      warning.details &&
      warning.details.includes('source-map-loader')
    );
  },
],

But when you make yarn install or npm install, yours edits will be deleted.

Thury answered 30/6, 2022 at 7:49 Comment(3)
Its bad practice to edit anything in node_modulesRus
@Matt Nienow I know it, but at now l don't know better solution in create-react-app. If you know better solution - write please! In my incident it happens after add antd 4.21Thury
@Thury you can use either craco or customize-cra.Thursby

© 2022 - 2024 — McMap. All rights reserved.