2020-01-25 09:41:34 +01:00
const cssnano = require ( 'cssnano' ) ;
2020-01-28 08:30:39 +01:00
const fastGlob = require ( 'fast-glob' ) ;
const FixStyleOnlyEntriesPlugin = require ( 'webpack-fix-style-only-entries' ) ;
2020-01-25 09:41:34 +01:00
const MiniCssExtractPlugin = require ( 'mini-css-extract-plugin' ) ;
const OptimizeCSSAssetsPlugin = require ( 'optimize-css-assets-webpack-plugin' ) ;
const PostCSSPresetEnv = require ( 'postcss-preset-env' ) ;
2020-01-28 08:30:39 +01:00
const PostCSSSafeParser = require ( 'postcss-safe-parser' ) ;
2020-02-11 11:02:41 -06:00
const SpriteLoaderPlugin = require ( 'svg-sprite-loader/plugin' ) ;
2020-01-28 08:30:39 +01:00
const TerserPlugin = require ( 'terser-webpack-plugin' ) ;
const VueLoaderPlugin = require ( 'vue-loader/lib/plugin' ) ;
2020-02-01 16:12:41 +01:00
const { statSync } = require ( 'fs' ) ;
2020-01-28 08:30:39 +01:00
const { resolve , parse } = require ( 'path' ) ;
const { SourceMapDevToolPlugin } = require ( 'webpack' ) ;
2020-02-11 11:02:41 -06:00
const glob = ( pattern ) => fastGlob . sync ( pattern , { cwd : _ _dirname , absolute : true } ) ;
2020-01-28 08:30:39 +01:00
const themes = { } ;
2020-02-11 11:02:41 -06:00
for ( const path of glob ( 'web_src/less/themes/*.less' ) ) {
2020-01-28 08:30:39 +01:00
themes [ parse ( path ) . name ] = [ path ] ;
}
2019-11-13 22:52:13 +08:00
2020-02-23 09:47:42 +01:00
const isProduction = process . env . NODE _ENV !== 'development' ;
2019-11-13 22:52:13 +08:00
module . exports = {
2020-02-23 09:47:42 +01:00
mode : isProduction ? 'production' : 'development' ,
2019-11-13 22:52:13 +08:00
entry : {
2020-01-28 08:30:39 +01:00
index : [
resolve ( _ _dirname , 'web_src/js/index.js' ) ,
resolve ( _ _dirname , 'web_src/less/index.less' ) ,
] ,
swagger : [
2020-02-07 18:09:30 +01:00
resolve ( _ _dirname , 'web_src/js/standalone/swagger.js' ) ,
2020-01-28 08:30:39 +01:00
] ,
jquery : [
resolve ( _ _dirname , 'web_src/js/jquery.js' ) ,
] ,
2020-02-11 11:02:41 -06:00
icons : glob ( 'node_modules/@primer/octicons/build/svg/**/*.svg' ) ,
2020-01-28 08:30:39 +01:00
... themes ,
2019-11-13 22:52:13 +08:00
} ,
2020-01-14 19:02:08 +01:00
devtool : false ,
2019-11-13 22:52:13 +08:00
output : {
2020-01-28 08:30:39 +01:00
path : resolve ( _ _dirname , 'public' ) ,
2020-01-25 09:41:34 +01:00
filename : 'js/[name].js' ,
chunkFilename : 'js/[name].js' ,
2019-11-13 22:52:13 +08:00
} ,
optimization : {
2020-02-23 09:47:42 +01:00
minimize : isProduction ,
2020-01-25 09:41:34 +01:00
minimizer : [
new TerserPlugin ( {
sourceMap : true ,
extractComments : false ,
terserOptions : {
output : {
comments : false ,
} ,
2019-11-17 22:39:06 +01:00
} ,
2020-01-25 09:41:34 +01:00
} ) ,
new OptimizeCSSAssetsPlugin ( {
cssProcessor : cssnano ,
cssProcessorOptions : {
parser : PostCSSSafeParser ,
} ,
cssProcessorPluginOptions : {
preset : [
'default' ,
{
discardComments : {
removeAll : true ,
} ,
} ,
] ,
} ,
} ) ,
] ,
2020-01-28 22:57:20 +01:00
splitChunks : {
chunks : 'async' ,
name : ( _ , chunks ) => chunks . map ( ( item ) => item . name ) . join ( '-' ) ,
}
2019-11-13 22:52:13 +08:00
} ,
2019-11-14 22:39:51 +01:00
module : {
rules : [
2020-01-20 12:07:30 +02:00
{
test : /\.vue$/ ,
exclude : /node_modules/ ,
2020-01-25 09:41:34 +01:00
loader : 'vue-loader' ,
2020-01-20 12:07:30 +02:00
} ,
2019-11-14 22:39:51 +01:00
{
test : /\.js$/ ,
exclude : /node_modules/ ,
2020-01-22 07:35:29 +01:00
use : [
{
loader : 'babel-loader' ,
options : {
2020-02-01 16:12:41 +01:00
cacheDirectory : true ,
cacheCompression : false ,
cacheIdentifier : [
resolve ( _ _dirname , 'package.json' ) ,
resolve ( _ _dirname , 'package-lock.json' ) ,
resolve ( _ _dirname , 'webpack.config.js' ) ,
] . map ( ( path ) => statSync ( path ) . mtime . getTime ( ) ) . join ( ':' ) ,
2020-02-23 09:47:42 +01:00
sourceMaps : true ,
2020-01-22 07:35:29 +01:00
presets : [
[
'@babel/preset-env' ,
{
useBuiltIns : 'usage' ,
corejs : 3 ,
2020-01-25 09:41:34 +01:00
} ,
] ,
2020-01-20 12:07:30 +02:00
] ,
2020-01-22 07:35:29 +01:00
plugins : [
[
'@babel/plugin-transform-runtime' ,
{
regenerator : true ,
}
] ,
'@babel/plugin-proposal-object-rest-spread' ,
] ,
2020-01-25 09:41:34 +01:00
} ,
2020-01-22 07:35:29 +01:00
} ,
] ,
2019-11-17 22:39:06 +01:00
} ,
{
2020-01-28 08:30:39 +01:00
test : /\.(less|css)$/i ,
2020-01-25 09:41:34 +01:00
use : [
{
loader : MiniCssExtractPlugin . loader ,
} ,
{
loader : 'css-loader' ,
options : {
2020-01-28 08:30:39 +01:00
importLoaders : 2 ,
url : false ,
2020-01-25 09:41:34 +01:00
}
} ,
{
loader : 'postcss-loader' ,
options : {
plugins : ( ) => [
PostCSSPresetEnv ( ) ,
] ,
} ,
} ,
2020-01-28 08:30:39 +01:00
{
loader : 'less-loader' ,
} ,
2020-01-25 09:41:34 +01:00
] ,
2019-11-17 22:39:06 +01:00
} ,
2020-02-11 11:02:41 -06:00
{
test : /\.svg$/ ,
use : [
{
loader : 'svg-sprite-loader' ,
options : {
extract : true ,
spriteFilename : 'img/svg/icons.svg' ,
symbolId : ( path ) => {
const { name } = parse ( path ) ;
if ( /@primer[/\\]octicons/ . test ( path ) ) {
return ` octicon- ${ name } ` ;
}
return name ;
} ,
} ,
} ,
{
loader : 'svgo-loader' ,
} ,
] ,
} ,
2020-01-25 09:41:34 +01:00
] ,
2020-01-14 19:02:08 +01:00
} ,
plugins : [
2020-01-20 12:07:30 +02:00
new VueLoaderPlugin ( ) ,
2020-02-11 11:02:41 -06:00
// avoid generating useless js output files for css- and svg-only chunks
2020-01-28 08:30:39 +01:00
new FixStyleOnlyEntriesPlugin ( {
2020-02-11 11:02:41 -06:00
extensions : [ 'less' , 'scss' , 'css' , 'svg' ] ,
2020-01-28 08:30:39 +01:00
silent : true ,
} ) ,
2020-01-25 09:41:34 +01:00
new MiniCssExtractPlugin ( {
filename : 'css/[name].css' ,
chunkFilename : 'css/[name].css' ,
} ) ,
2020-01-14 19:02:08 +01:00
new SourceMapDevToolPlugin ( {
2020-01-25 09:41:34 +01:00
filename : 'js/[name].js.map' ,
2020-01-28 22:57:20 +01:00
include : [
'js/index.js' ,
2020-01-14 19:02:08 +01:00
] ,
} ) ,
2020-02-11 11:02:41 -06:00
new SpriteLoaderPlugin ( {
plainSprite : true ,
} ) ,
2020-01-14 19:02:08 +01:00
] ,
performance : {
2020-02-23 09:47:42 +01:00
hints : isProduction ? 'warning' : false ,
2020-01-21 18:32:33 +01:00
maxEntrypointSize : 512000 ,
maxAssetSize : 512000 ,
2020-01-14 19:02:08 +01:00
assetFilter : ( filename ) => {
2020-01-28 22:57:20 +01:00
if ( filename . endsWith ( '.map' ) ) return false ;
if ( [ 'js/swagger.js' , 'js/highlight.js' ] . includes ( filename ) ) return false ;
return true ;
2020-01-25 09:41:34 +01:00
} ,
2020-01-14 19:02:08 +01:00
} ,
2020-01-22 07:35:29 +01:00
resolve : {
symlinks : false ,
2020-02-23 22:34:28 +01:00
alias : {
vue$ : 'vue/dist/vue.esm.js' , // needed because vue's default export is the runtime only
} ,
2020-01-25 09:41:34 +01:00
} ,
2020-02-23 09:47:42 +01:00
watchOptions : {
ignored : [
'node_modules/**' ,
] ,
} ,
2019-11-13 22:52:13 +08:00
} ;