webpack-contrib / file-loader

File Loader
MIT License
1.86k stars 257 forks source link

url-loader filling files with base64 #337

Closed MichaelJCole closed 5 years ago

MichaelJCole commented 5 years ago

See this repo: https://github.com/MichaelJCole/webpack-file-loader

Notes in these files: https://github.com/MichaelJCole/webpack-file-loader/search?q=ISSUE_HERE&unscoped_q=ISSUE_HERE

Expected Behavior

    /* ISSUE_HERE (1/3)

    Hello!  And Welcome To The Internet!

    This is a [Quasar](http://quasar.dev) config file.
    This section extends web pack.

    Also included is [phaser.io](phaser.io) - a HTML game engine packaged in npm.
    To see the original problem, comment out the rest of this
    function and run `yarn && quasar dev`

    ```
    Error: Local data URIs are not supported: player
    ```

    This error happens because webpack made the file into a dataurl.
    Phaser wants to load resources over XHR, so would like URL instead.
    Phaser refuses to implement data urls in it's loader.

    The code below is my attempt to configure Quasar's webpack to process
    these files so they can be loaded in phaser via XHR
    */

Actual Behavior

    /* ISSUE_HERE (2/3)
    Webpack created these files (output in browser console)
    ```
    1b7d460ae0a1b62ad310366012bc4e20.png
    c5b05634518f62135bc6b754594d352c.png
    85b0e130bbe4ecce34b3ee50f6596906.png
    f36c557a87c9f3eb8a7e12c729e50d9a.png
    ```
    but the file contents are text:

    ```
    $ curl --insecure https://localhost:8080/1b7d460ae0a1b62ad310366012bc4e20.png
    module.exports = ""%
    ```

    Even when "built" to files
    ```
    $ quasar build
    $ cat test/dist/spa/1b7d460ae0a1b62ad310366012bc4e20.png)

    module.exports = ""%
    ```

    Which is a long long way to go to get the wrong thing :-)
    */

Code

This is cfg.modules.rules

{ test: /\.vue$/,
  use: [ { loader: 'vue-loader', options: [Object] } ] }
{ test: /\.jsx?$/,
  exclude: [ [Function] ],
  use: [ { loader: 'babel-loader', options: [Object] } ] }
{ include: /src\/games/,
  test: [ /\.vert$/i, /\.frag$/i ],
  use: 'raw-loader' }
{ include: /src\/games/,
  test: /\.(gif|png|jpe?g|svg|xml|mp3)$/i,
  use: 'file-loader' }
{ test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
  use: [ { loader: 'url-loader', options: [Object] } ] }
{ test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
  use: [ { loader: 'url-loader', options: [Object] } ] }
{ test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
  use: [ { loader: 'url-loader', options: [Object] } ] }
{ test: /\.css$/,
  oneOf: 
   [ { resourceQuery: /module/, use: [Array] },
     { test: /\.module\.\w+$/, use: [Array] },
     { use: [Array] } ] }
{ test: /\.styl(us)?$/,
  oneOf: 
   [ { resourceQuery: /module/, use: [Array] },
     { test: /\.module\.\w+$/, use: [Array] },
     { use: [Array] } ] }
{ test: /\.scss$/,
  oneOf: 
   [ { resourceQuery: /module/, use: [Array] },
     { test: /\.module\.\w+$/, use: [Array] },
     { use: [Array] } ] }
{ test: /\.sass$/,
  oneOf: 
   [ { resourceQuery: /module/, use: [Array] },
     { test: /\.module\.\w+$/, use: [Array] },
     { use: [Array] } ] }
{ test: /\.less$/,
  oneOf: 
   [ { resourceQuery: /module/, use: [Array] },
     { test: /\.module\.\w+$/, use: [Array] },
     { use: [Array] } ] }
{ enforce: 'pre',
  test: /\.(js|vue)$/,
  loader: 'eslint-loader',
  exclude: /node_modules/,
  options: { formatter: [Function] } }

How Do We Reproduce?

See this repo: https://github.com/MichaelJCole/webpack-file-loader

Notes in these files: https://github.com/MichaelJCole/webpack-file-loader/search?q=ISSUE_HERE&unscoped_q=ISSUE_HERE

MichaelJCole commented 5 years ago

I figured out a working setup on my end and I am not sure this is a bug after all.

My solution was to use this in quasar.conf.js:

      extendWebpack (cfg) {

        // eslint errors in browser(?)
        cfg.module.rules.push({
          enforce: 'pre',
          test: /\.(js|vue)$/,
          loader: 'eslint-loader',
          exclude: /node_modules/,
          options: {
            formatter: require('eslint').CLIEngine.getFormatter('stylish')
          }
        })

        // phaser wants files as URL's for XHR requests.  refuses to load data urls

        // exclude phaser assets from existing rules
        cfg.module.rules.forEach(rule => {
          try {
            if (rule.use[0].loader === 'url-loader') {
              rule.exclude = /src\/phaser/
            }
          } catch (e) {}
        })
        // Add rules for phaser assets
        cfg.module.rules.push({
          include: /src\/phaser/,
          test: [/\.vert$/i, /\.frag$/i],
          use: 'raw-loader'
        },
        {
          include: /src\/phaser/,
          test: /\.(gif|png|jpe?g|svg|xml|mp3|svg|woff|woff2)$/i,
          use: 'file-loader'
        }
        )
      }
    },