* Configure webpack to poll for changes in development Vagrant on Linux/macOS hosts shared files via NFS, which doens't support inotify-based watching of files. This tweak makes webpack check for changes every second, and rebuild if necessary. This removes the need to restart Foreman every time a frontend file changes. Note that rebuilding is still a relatively lengthy process. The polling frequency can be changed to taste. * Only poll in Vagrant This tests for the presence of the VAGRANT environment variable to determine whether or not we're in Vagrant. It is set in .env.vagrant, which is set up to be included in the Vagrantfile.
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Note: You must restart bin/webpack-dev-server for changes to take effect
 | |
| 
 | |
| const merge = require('webpack-merge');
 | |
| const sharedConfig = require('./shared.js');
 | |
| const { settings, output } = require('./configuration.js');
 | |
| 
 | |
| const watchOptions = {
 | |
|   ignored: /node_modules/,
 | |
| };
 | |
| 
 | |
| if (process.env.VAGRANT) {
 | |
|   // If we are in Vagrant, we can't rely on inotify to update us with changed
 | |
|   // files, so we must poll instead. Here, we poll every second to see if
 | |
|   // anything has changed.
 | |
|   watchOptions.poll = 1000;
 | |
| }
 | |
| 
 | |
| module.exports = merge(sharedConfig, {
 | |
|   devtool: 'cheap-module-eval-source-map',
 | |
| 
 | |
|   stats: {
 | |
|     errorDetails: true,
 | |
|   },
 | |
| 
 | |
|   output: {
 | |
|     pathinfo: true,
 | |
|   },
 | |
| 
 | |
|   devServer: {
 | |
|     clientLogLevel: 'none',
 | |
|     https: settings.dev_server.https,
 | |
|     host: settings.dev_server.host,
 | |
|     port: settings.dev_server.port,
 | |
|     contentBase: output.path,
 | |
|     publicPath: output.publicPath,
 | |
|     compress: true,
 | |
|     headers: { 'Access-Control-Allow-Origin': '*' },
 | |
|     historyApiFallback: true,
 | |
|     disableHostCheck: true,
 | |
|     watchOptions: watchOptions,
 | |
|   },
 | |
| });
 |