Fix webpack compliation for prod, chunk out massive files for perf
This commit is contained in:
		
							parent
							
								
									cc6d10d7f8
								
							
						
					
					
						commit
						91cf735646
					
				| @ -42,6 +42,9 @@ | ||||
|         @show | ||||
|         @section('scripts') | ||||
|             {!! $asset->js('main.js') !!} | ||||
|             {!! $asset->js('vue.js') !!} | ||||
|             {!! $asset->js('vendor.js') !!} | ||||
|             {!! $asset->js('locales.js') !!} | ||||
|         @show | ||||
|     </body> | ||||
| </html> | ||||
|  | ||||
| @ -21,7 +21,7 @@ let plugins = [ | ||||
|             'php artisan ziggy:generate resources/assets/scripts/helpers/ziggy.js', | ||||
|         ], | ||||
|     }), | ||||
|     new MiniCssExtractPlugin({ filename: 'bundle.[hash:8].css' }), | ||||
|     new MiniCssExtractPlugin({ filename: isProduction ? 'bundle.[chunkhash:8].css' : 'bundle.[hash:8].css' }), | ||||
|     new AssetsManifestPlugin({ | ||||
|         writeToDisk: true, | ||||
|         publicPath: true, | ||||
| @ -50,7 +50,7 @@ if (isProduction) { | ||||
|                             return content.match(/[A-z0-9-:\/]+/g) || []; | ||||
|                         } | ||||
|                     }, | ||||
|                     extensions: ['html', 'js', 'php', 'vue'], | ||||
|                     extensions: ['html', 'ts', 'js', 'php', 'vue'], | ||||
|                 }, | ||||
|             ], | ||||
|         }), | ||||
| @ -114,8 +114,8 @@ module.exports = { | ||||
|     entry: ['./resources/assets/styles/main.css', './resources/assets/scripts/app.ts'], | ||||
|     output: { | ||||
|         path: path.resolve(__dirname, 'public/assets'), | ||||
|         filename: 'bundle.[hash:8].js', | ||||
|         chunkFilename: 'chunk.[name].js', | ||||
|         filename: isProduction ? 'bundle.[chunkhash:8].js' : 'bundle.[hash:8].js', | ||||
|         chunkFilename: isProduction ? '[name].[chunkhash:8].js' : '[name].[hash:8].js', | ||||
|         publicPath: _.get(process.env, 'PUBLIC_PATH', '') + '/assets/', | ||||
|         crossOriginLoading: 'anonymous', | ||||
|     }, | ||||
| @ -125,6 +125,18 @@ module.exports = { | ||||
|                 test: /\.vue$/, | ||||
|                 loader: 'vue-loader', | ||||
|             }, | ||||
|             { | ||||
|                 test: /\.js$/, | ||||
|                 loader: 'babel-loader', | ||||
|                 options: { | ||||
|                     cacheDirectory: !isProduction, | ||||
|                     presets: ['@babel/preset-env'], | ||||
|                     plugins: [ | ||||
|                         '@babel/plugin-proposal-class-properties', | ||||
|                         ['@babel/plugin-proposal-object-rest-spread', { 'useBuiltIns': true }] | ||||
|                     ], | ||||
|                 }, | ||||
|             }, | ||||
|             { | ||||
|                 test: /\.ts$/, | ||||
|                 exclude: /node_modules/, | ||||
| @ -167,6 +179,25 @@ module.exports = { | ||||
|                 }, | ||||
|             }), | ||||
|         ], | ||||
|         splitChunks: { | ||||
|             cacheGroups: { | ||||
|                 vue: { | ||||
|                     test: /[\\/]node_modules[\\/](vue\w?)[\\/]/, | ||||
|                     name: 'vue', | ||||
|                     chunks: 'initial', | ||||
|                 }, | ||||
|                 locales: { | ||||
|                     test: /locales/, | ||||
|                     name: 'locales', | ||||
|                     chunks: 'initial', | ||||
|                 }, | ||||
|                 vendors: { | ||||
|                     test: /[\\/]node_modules[\\/](?!vue)(.*)[\\/]/, | ||||
|                     name: 'vendor', | ||||
|                     chunks: 'initial', | ||||
|                 }, | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     devServer: { | ||||
|         contentBase: path.join(__dirname, 'public'), | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dane Everitt
						Dane Everitt