Search code examples
wordpresswebpackwebpack-hmr

Enqueuing Script in WordPress while doing Webpack-Dev-Server HMR


I'm trying to be a good WordPress Citizen 😇 and including my JavaScript the right way, via wp_enqueue_scripts in my functions.php.

However doing it this way I don't get hot module reloading (hmr) via webpack-dev-server to work.

Can anybody give me a hint or point me to some documentation?


Solution

  • No reaction here, so I was forced to look for an answer by myself. 😉 Here it is.

    What I did not get was how to make the bundle.js file, which webpack-dev-server makes available just in memory, available to WordPress using wp_enqueue_scripts in the functions.php.

    my webpack.config.js (extract)

    const webpack = require('webpack');
    
    module.exports = {
      entry: './src/entry.js',
      output: {
        path: __dirname,
        publicPath: '/',
        filename: 'bundle.js'
      },
      module: {
        rules: [
          {
            test: /\.(js|jsx)$/,
            exclude: /node_modules/,
            use: ['babel-loader']
          }
        ]
      },
      devServer: {
        open: true,
        hot: true,
        publicPath: '/',
        proxy: {
          '/': {
            target: 'http://wordpress:8888/',
            changeOrigin: true
          }
        }
      },
      plugins: [new webpack.HotModuleReplacementPlugin()]
    };
    

    The thing is: Although I proxy the dev-sever through my MAMP-server, which runs under http://wordpress:8888 the build.js file is not made available by webpack-dev-server under http://wordpress:8888/build.js but under the original url, which is http://localhost:8080/build.js.

    Once I got that a conditional statement in the functions.php did the trick.

    my functions.php (extract)

    <?php
    
    // Load my JS
    if (!defined('WP_ENVIRONMENT') || WP_ENVIRONMENT == "production") {
    
      function reactTheme_enque_scripts() {
        wp_enqueue_script(
          'react-theme-js',
          get_stylesheet_directory_uri() . '/bundle.js',
          [], // dependencies could go here
          time(), // version for caching
          true // loading it within footer
        );
      }
    
    } else {
    
      function reactTheme_enque_scripts() {
        wp_enqueue_script(
          'react-theme-js',
          'http://localhost:8080' . '/bundle.js',
          [], // dependencies could go here
          time(), // version for caching
          true // loading it within footer
        );
      }
    
    }
    
    add_action('wp_enqueue_scripts', 'reactTheme_enque_scripts');
    
    ?>
    

    So by now just adding one line within the wp-config.php I can WordPress make looking for the bundle.js file, where webpack-dev-server is putting it. If this line is missing, it loads the bundle.js file from the root of the theme directory.

    my wp-config.php (extract)

    define('WP_ENVIRONMENT', 'development');