|
1
|
|
|
/* |
|
2
|
|
|
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony) |
|
3
|
|
|
* |
|
4
|
|
|
* Copyright (C) 2019 - 2023 Jan Böhmer (https://github.com/jbtronics) |
|
5
|
|
|
* |
|
6
|
|
|
* This program is free software; you can redistribute it and/or |
|
7
|
|
|
* modify it under the terms of the GNU General Public License |
|
8
|
|
|
* as published by the Free Software Foundation; either version 2 |
|
9
|
|
|
* of the License, or (at your option) any later version. |
|
10
|
|
|
* |
|
11
|
|
|
* This program is distributed in the hope that it will be useful, |
|
12
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
13
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
14
|
|
|
* GNU General Public License for more details. |
|
15
|
|
|
* |
|
16
|
|
|
* You should have received a copy of the GNU General Public License |
|
17
|
|
|
* along with this program; if not, write to the Free Software |
|
18
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA |
|
19
|
|
|
* |
|
20
|
|
|
*/ |
|
21
|
|
|
|
|
22
|
|
|
var Encore = require('@symfony/webpack-encore'); |
|
23
|
|
|
|
|
24
|
|
|
const zlib = require('zlib'); |
|
|
|
|
|
|
25
|
|
|
const CompressionPlugin = require("compression-webpack-plugin"); |
|
26
|
|
|
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; |
|
27
|
|
|
const CKEditorWebpackPlugin = require( '@ckeditor/ckeditor5-dev-webpack-plugin' ); |
|
28
|
|
|
const { styles } = require( '@ckeditor/ckeditor5-dev-utils' ); |
|
29
|
|
|
|
|
30
|
|
|
// Manually configure the runtime environment if not already configured yet by the "encore" command. |
|
31
|
|
|
// It's useful when you use tools that rely on webpack.config.js file. |
|
32
|
|
|
if (!Encore.isRuntimeEnvironmentConfigured()) { |
|
33
|
|
|
Encore.configureRuntimeEnvironment(process.env.NODE_ENV || 'dev'); |
|
34
|
|
|
} |
|
35
|
|
|
|
|
36
|
|
|
Encore |
|
37
|
|
|
// directory where compiled assets will be stored |
|
38
|
|
|
.setOutputPath('public/build/') |
|
39
|
|
|
// public path used by the web server to access the output path |
|
40
|
|
|
.setPublicPath('/build') |
|
41
|
|
|
// only needed for CDN's or subdirectory deploy |
|
42
|
|
|
//.setManifestKeyPrefix('build/') |
|
43
|
|
|
|
|
44
|
|
|
/** |
|
45
|
|
|
* If you are putting Part-DB into a sub directory you have to uncomment these lines and |
|
46
|
|
|
* replace "part-db/" with your path to Part-DB |
|
47
|
|
|
*/ |
|
48
|
|
|
//.setPublicPath('/part-db/build') |
|
49
|
|
|
//.setManifestKeyPrefix('build/') |
|
50
|
|
|
|
|
51
|
|
|
/* |
|
52
|
|
|
* ENTRY CONFIG |
|
53
|
|
|
* |
|
54
|
|
|
* Add 1 entry for each "page" of your app |
|
55
|
|
|
* (including one that's included on every page - e.g. "app") |
|
56
|
|
|
* |
|
57
|
|
|
* Each entry will result in one JavaScript file (e.g. app.js) |
|
58
|
|
|
* and one CSS file (e.g. app.css) if you JavaScript imports CSS. |
|
59
|
|
|
*/ |
|
60
|
|
|
.addEntry('app', './assets/js/app.js') |
|
61
|
|
|
.addEntry('webauthn_tfa', './assets/js/webauthn_tfa.js') |
|
62
|
|
|
|
|
63
|
|
|
|
|
64
|
|
|
|
|
65
|
|
|
|
|
66
|
|
|
// enables the Symfony UX Stimulus bridge (used in assets/bootstrap.js) |
|
67
|
|
|
.enableStimulusBridge('./assets/controllers.json') |
|
68
|
|
|
//.addEntry('page1', './assets/js/page1.js') |
|
69
|
|
|
//.addEntry('page2', './assets/js/page2.js') |
|
70
|
|
|
|
|
71
|
|
|
// When enabled, Webpack "splits" your files into smaller pieces for greater optimization. |
|
72
|
|
|
.splitEntryChunks() |
|
73
|
|
|
|
|
74
|
|
|
// will require an extra script tag for runtime.js |
|
75
|
|
|
// but, you probably want this, unless you're building a single-page app |
|
76
|
|
|
.enableSingleRuntimeChunk() |
|
77
|
|
|
|
|
78
|
|
|
/* |
|
79
|
|
|
* FEATURE CONFIG |
|
80
|
|
|
* |
|
81
|
|
|
* Enable & configure other features below. For a full |
|
82
|
|
|
* list of features, see: |
|
83
|
|
|
* https://symfony.com/doc/current/frontend.html#adding-more-features |
|
84
|
|
|
*/ |
|
85
|
|
|
.cleanupOutputBeforeBuild() |
|
86
|
|
|
.enableBuildNotifications() |
|
87
|
|
|
.enableSourceMaps(!Encore.isProduction()) |
|
88
|
|
|
// enables hashed filenames (e.g. app.abc123.css) |
|
89
|
|
|
//.enableVersioning(Encore.isProduction()) |
|
90
|
|
|
.enableVersioning() |
|
91
|
|
|
|
|
92
|
|
|
|
|
93
|
|
|
|
|
94
|
|
|
// configure Babel |
|
95
|
|
|
// .configureBabel((config) => { |
|
96
|
|
|
// config.plugins.push('@babel/a-babel-plugin'); |
|
97
|
|
|
// }) |
|
98
|
|
|
|
|
99
|
|
|
// enables and configure @babel/preset-env polyfills |
|
100
|
|
|
.configureBabelPresetEnv((config) => { |
|
101
|
|
|
config.useBuiltIns = 'usage'; |
|
102
|
|
|
config.corejs = '3.23'; |
|
103
|
|
|
}) |
|
104
|
|
|
// enables Sass/SCSS support |
|
105
|
|
|
//.enableSassLoader() |
|
106
|
|
|
|
|
107
|
|
|
// uncomment if you use TypeScript |
|
108
|
|
|
.enableTypeScriptLoader() |
|
109
|
|
|
|
|
110
|
|
|
// uncomment if you use React |
|
111
|
|
|
//.enableReactPreset() |
|
112
|
|
|
|
|
113
|
|
|
// uncomment to get integrity="..." attributes on your script & link tags |
|
114
|
|
|
// requires WebpackEncoreBundle 1.4 or higher |
|
115
|
|
|
.enableIntegrityHashes(Encore.isProduction()) |
|
116
|
|
|
|
|
117
|
|
|
// uncomment if you're having problems with a jQuery plugin |
|
118
|
|
|
.autoProvidejQuery() |
|
119
|
|
|
|
|
120
|
|
|
.addPlugin( new CKEditorWebpackPlugin( { |
|
121
|
|
|
// See https://ckeditor.com/docs/ckeditor5/latest/features/ui-language.html |
|
122
|
|
|
language: 'en', |
|
123
|
|
|
addMainLanguageTranslationsToAllAssets: true, |
|
124
|
|
|
additionalLanguages: 'all', |
|
125
|
|
|
outputDirectory: 'ckeditor_translations' |
|
126
|
|
|
} ) ) |
|
127
|
|
|
|
|
128
|
|
|
// Use raw-loader for CKEditor 5 SVG files. |
|
129
|
|
|
.addRule( { |
|
130
|
|
|
test: /ckeditor5-[^/\\]+[/\\]theme[/\\]icons[/\\][^/\\]+\.svg$/, |
|
131
|
|
|
loader: 'raw-loader' |
|
132
|
|
|
} ) |
|
133
|
|
|
|
|
134
|
|
|
// Configure other image loaders to exclude CKEditor 5 SVG files. |
|
135
|
|
|
.configureLoaderRule( 'images', loader => { |
|
136
|
|
|
loader.exclude = /ckeditor5-[^/\\]+[/\\]theme[/\\]icons[/\\][^/\\]+\.svg$/; |
|
137
|
|
|
} ) |
|
138
|
|
|
|
|
139
|
|
|
// Configure PostCSS loader. |
|
140
|
|
|
.addLoader({ |
|
141
|
|
|
test: /ckeditor5-[^/\\]+[/\\]theme[/\\].+\.css$/, |
|
142
|
|
|
loader: 'postcss-loader', |
|
143
|
|
|
options: { |
|
144
|
|
|
postcssOptions: styles.getPostCssConfig( { |
|
145
|
|
|
themeImporter: { |
|
146
|
|
|
themePath: require.resolve( '@ckeditor/ckeditor5-theme-lark' ) |
|
147
|
|
|
}, |
|
148
|
|
|
minify: true |
|
149
|
|
|
} ) |
|
150
|
|
|
} |
|
151
|
|
|
} ) |
|
152
|
|
|
|
|
153
|
|
|
; |
|
154
|
|
|
|
|
155
|
|
|
//These are all the themes that are available in bootswatch |
|
156
|
|
|
const AVAILABLE_THEMES = ['bootstrap', 'cerulean', 'cosmo', 'cyborg', 'darkly', 'flatly', 'journal', |
|
157
|
|
|
'litera', 'lumen', 'lux', 'materia', 'minty', 'morph', 'pulse', 'quartz', 'sandstone', 'simplex', 'sketchy', 'slate', 'solar', |
|
158
|
|
|
'spacelab', 'superhero', 'united', 'vapor', 'yeti', 'zephyr']; |
|
159
|
|
|
|
|
160
|
|
|
for (const theme of AVAILABLE_THEMES) { |
|
161
|
|
|
Encore.addEntry('theme_' + theme, './assets/themes/'+theme+'.js'); |
|
162
|
|
|
} |
|
163
|
|
|
|
|
164
|
|
|
|
|
165
|
|
|
if (Encore.isProduction()) { |
|
166
|
|
|
Encore.addPlugin(new CompressionPlugin({ |
|
167
|
|
|
filename: '[path][base].br', |
|
168
|
|
|
algorithm: 'brotliCompress', |
|
169
|
|
|
test: /\.(js|css|html|svg)$/, |
|
170
|
|
|
compressionOptions: { |
|
171
|
|
|
// zlib’s `level` option matches Brotli’s `BROTLI_PARAM_QUALITY` option. |
|
172
|
|
|
level: 11, |
|
173
|
|
|
}, |
|
174
|
|
|
//threshold: 10240, |
|
175
|
|
|
minRatio: 0.8, |
|
176
|
|
|
deleteOriginalAssets: false, |
|
177
|
|
|
})) |
|
178
|
|
|
|
|
179
|
|
|
.addPlugin(new CompressionPlugin({ |
|
180
|
|
|
filename: '[path][base].gz', |
|
181
|
|
|
algorithm: 'gzip', |
|
182
|
|
|
test: /\.(js|css|html|svg)$/, |
|
183
|
|
|
deleteOriginalAssets: false, |
|
184
|
|
|
})) |
|
185
|
|
|
} |
|
186
|
|
|
|
|
187
|
|
|
if (Encore.isDev()) { |
|
188
|
|
|
//Only uncomment if needed, as this cause problems with Github actions (job does not finish) |
|
189
|
|
|
Encore.addPlugin(new BundleAnalyzerPlugin()); |
|
190
|
|
|
} |
|
191
|
|
|
|
|
192
|
|
|
|
|
193
|
|
|
module.exports = Encore.getWebpackConfig(); |
|
194
|
|
|
|