mirror of
https://github.com/philomena-dev/philomena.git
synced 2025-01-19 22:27:59 +01:00
115 lines
2.9 KiB
JavaScript
115 lines
2.9 KiB
JavaScript
|
const path = require('path');
|
||
|
const TerserPlugin = require('terser-webpack-plugin');
|
||
|
const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
|
||
|
const CopyPlugin = require('copy-webpack-plugin');
|
||
|
|
||
|
const isDevelopment = process.env.NODE_ENV !== 'production';
|
||
|
|
||
|
const includePaths = require('rollup-plugin-includepaths')();
|
||
|
const multiEntry = require('rollup-plugin-multi-entry')();
|
||
|
const buble = require('rollup-plugin-buble')({ transforms: { dangerousForOf: true } });
|
||
|
|
||
|
let plugins = [
|
||
|
new CopyPlugin({
|
||
|
patterns: [
|
||
|
{ from: path.resolve(__dirname, 'static') },
|
||
|
],
|
||
|
}),
|
||
|
];
|
||
|
if (!isDevelopment){
|
||
|
plugins = plugins.concat([
|
||
|
new TerserPlugin({
|
||
|
cache: true,
|
||
|
parallel: true,
|
||
|
sourceMap: isDevelopment,
|
||
|
}),
|
||
|
new OptimizeCSSAssetsPlugin({
|
||
|
cssProcessorOptions: { discardComments: { removeAll: true } },
|
||
|
canPrint: true,
|
||
|
sourceMaps: isDevelopment,
|
||
|
}),
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
module.exports = {
|
||
|
mode: isDevelopment ? 'development' : 'production',
|
||
|
entry: {
|
||
|
'js/app.js': './js/app.js',
|
||
|
},
|
||
|
output: {
|
||
|
filename: '[name]',
|
||
|
path: path.resolve(__dirname, '../priv/static'),
|
||
|
},
|
||
|
optimization: {
|
||
|
minimize: !isDevelopment,
|
||
|
providedExports: true,
|
||
|
usedExports: true,
|
||
|
concatenateModules: true,
|
||
|
},
|
||
|
devtool: isDevelopment ? 'inline-source-map' : undefined,
|
||
|
performance: { hints: false },
|
||
|
resolve: {
|
||
|
alias: {
|
||
|
common: path.resolve(__dirname, 'css/common/'),
|
||
|
views: path.resolve(__dirname, 'css/views/')
|
||
|
}
|
||
|
},
|
||
|
module: {
|
||
|
rules: [
|
||
|
{
|
||
|
test: /\.(ttf|eot|svg|woff2?)$/,
|
||
|
loader: 'file-loader',
|
||
|
options: {
|
||
|
name: '[name].[ext]',
|
||
|
outputPath: './fonts',
|
||
|
publicPath: '../fonts',
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
test: /app\.js/,
|
||
|
use: [
|
||
|
{
|
||
|
loader: 'webpack-rollup-loader',
|
||
|
options: {
|
||
|
plugins: [
|
||
|
buble,
|
||
|
includePaths,
|
||
|
multiEntry,
|
||
|
]
|
||
|
}
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
{
|
||
|
test: /themes\/[a-z]+\.scss$/,
|
||
|
use: [
|
||
|
{
|
||
|
loader: 'file-loader',
|
||
|
options: {
|
||
|
sourceMaps: isDevelopment,
|
||
|
name: '[name].css',
|
||
|
outputPath: '/css',
|
||
|
publicPath: '/css',
|
||
|
},
|
||
|
},
|
||
|
{ loader: 'extract-loader', options: { sourceMaps: isDevelopment } },
|
||
|
{ loader: 'css-loader', options: { sourceMap: isDevelopment } },
|
||
|
{
|
||
|
loader: 'postcss-loader',
|
||
|
options: {
|
||
|
sourceMaps: isDevelopment,
|
||
|
ident: 'postcss',
|
||
|
syntax: 'postcss-scss',
|
||
|
plugins: [
|
||
|
require('autoprefixer')(),
|
||
|
],
|
||
|
},
|
||
|
},
|
||
|
{ loader: 'sass-loader', options: { sourceMap: isDevelopment } },
|
||
|
],
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
plugins,
|
||
|
};
|