-
-
Notifications
You must be signed in to change notification settings - Fork 14
/
webpack.config.js
59 lines (49 loc) · 1.67 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
const Encore = require('@symfony/webpack-encore');
const WorkboxPlugin = require('workbox-webpack-plugin');
if (!Encore.isRuntimeEnvironmentConfigured()) {
Encore.configureRuntimeEnvironment(process.env.NODE_ENV || 'dev');
}
Encore
.setOutputPath('public/assets/')
.setPublicPath('/assets')
.addEntry('app', './assets/app/index.js')
.addEntry('admin', './assets/admin/index.js')
.enableStimulusBridge('./assets/shared/controllers.json')
.splitEntryChunks()
.enableSingleRuntimeChunk()
.cleanupOutputBeforeBuild()
.enableBuildNotifications()
.enableSourceMaps(!Encore.isProduction())
.enableVersioning(Encore.isProduction())
.configureImageRule({type: 'asset', maxSize: 4 * 1024})
.configureFontRule({type: 'asset', maxSize: 4 * 1024})
.configureBabel((config) => {
config.plugins.push('@babel/plugin-proposal-class-properties');
})
.configureBabelPresetEnv((config) => {
config.useBuiltIns = 'usage';
config.corejs = 3;
})
.enableSassLoader()
.enablePostCssLoader((config) => {
config.postcssOptions = {
path: './postcss.config.js'
};
})
.enableIntegrityHashes(Encore.isProduction())
;
// service worker precache assets
Encore.addPlugin(new WorkboxPlugin.InjectManifest({
additionalManifestEntries: [],
include: [
/^css.(.+)?(css|js)$/,
],
maximumFileSizeToCacheInBytes: 5 * 1024 * 1024,
swSrc: './assets/app/js/sw.js',
swDest: '../sw.js', // public/sw.js
mode: Encore.isProduction ? 'production' : 'development'
}), -10);
Encore.addExternals({
'bootstrap': 'bootstrap'
})
module.exports = Encore.getWebpackConfig();