Use the CockpitRsyncWebpack plugin to optionally rsync build code to a remote machine, the destination is determined by looking at the package.json's name field.
148 lines
4.9 KiB
JavaScript
148 lines
4.9 KiB
JavaScript
const fs = require("fs");
|
|
const path = require("path");
|
|
|
|
const copy = require("copy-webpack-plugin");
|
|
const extract = require("mini-css-extract-plugin");
|
|
const TerserJSPlugin = require('terser-webpack-plugin');
|
|
const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');
|
|
const CompressionPlugin = require("compression-webpack-plugin");
|
|
const ESLintPlugin = require('eslint-webpack-plugin');
|
|
const CockpitPoPlugin = require("./src/lib/cockpit-po-plugin");
|
|
const CockpitRsyncPlugin = require("./src/lib/cockpit-rsync-plugin");
|
|
|
|
/* A standard nodejs and webpack pattern */
|
|
const production = process.env.NODE_ENV === 'production';
|
|
|
|
// Obtain package name from package.json
|
|
const packageJson = JSON.parse(fs.readFileSync('package.json'));
|
|
|
|
// Non-JS files which are copied verbatim to dist/
|
|
const copy_files = [
|
|
"./src/index.html",
|
|
"./src/manifest.json",
|
|
];
|
|
|
|
const plugins = [
|
|
new copy({ patterns: copy_files }),
|
|
new extract({filename: "[name].css"}),
|
|
new ESLintPlugin({ extensions: ["js", "jsx"] }),
|
|
new CockpitPoPlugin(),
|
|
new CockpitRsyncPlugin({dest: packageJson.name}),
|
|
];
|
|
|
|
/* Only minimize when in production mode */
|
|
if (production) {
|
|
plugins.unshift(new CompressionPlugin({
|
|
test: /\.(js|html|css)$/,
|
|
deleteOriginalAssets: true
|
|
}));
|
|
}
|
|
|
|
module.exports = {
|
|
mode: production ? 'production' : 'development',
|
|
resolve: {
|
|
modules: [ "node_modules", path.resolve(__dirname, 'src/lib') ],
|
|
alias: { 'font-awesome': 'font-awesome-sass/assets/stylesheets' },
|
|
},
|
|
resolveLoader: {
|
|
modules: [ "node_modules", path.resolve(__dirname, 'src/lib') ],
|
|
},
|
|
watchOptions: {
|
|
ignored: /node_modules/,
|
|
},
|
|
entry: {
|
|
index: "./src/index.js",
|
|
},
|
|
// cockpit.js gets included via <script>, everything else should be bundled
|
|
externals: { "cockpit": "cockpit" },
|
|
devtool: "source-map",
|
|
stats: "errors-warnings",
|
|
|
|
optimization: {
|
|
minimize: production,
|
|
minimizer: [
|
|
new TerserJSPlugin({
|
|
extractComments: {
|
|
condition: true,
|
|
filename: `[file].LICENSE.txt?query=[query]&filebase=[base]`,
|
|
banner(licenseFile) {
|
|
return `License information can be found in ${licenseFile}`;
|
|
},
|
|
},
|
|
}),
|
|
new CssMinimizerPlugin()
|
|
],
|
|
},
|
|
|
|
module: {
|
|
rules: [
|
|
{
|
|
exclude: /node_modules/,
|
|
use: "babel-loader",
|
|
test: /\.(js|jsx)$/
|
|
},
|
|
/* HACK: remove unwanted fonts from PatternFly's css */
|
|
{
|
|
test: /patternfly-4-cockpit.scss$/,
|
|
use: [
|
|
extract.loader,
|
|
{
|
|
loader: 'css-loader',
|
|
options: {
|
|
sourceMap: true,
|
|
url: false,
|
|
},
|
|
},
|
|
{
|
|
loader: 'string-replace-loader',
|
|
options: {
|
|
multiple: [
|
|
{
|
|
search: /src:url\("patternfly-icons-fake-path\/pficon[^}]*/g,
|
|
replace: 'src:url("../base1/fonts/patternfly.woff") format("woff");',
|
|
},
|
|
{
|
|
search: /@font-face[^}]*patternfly-fonts-fake-path[^}]*}/g,
|
|
replace: '',
|
|
},
|
|
]
|
|
},
|
|
},
|
|
{
|
|
loader: 'sass-loader',
|
|
options: {
|
|
sourceMap: !production,
|
|
sassOptions: {
|
|
outputStyle: production ? 'compressed' : undefined,
|
|
},
|
|
},
|
|
},
|
|
]
|
|
},
|
|
{
|
|
test: /\.s?css$/,
|
|
exclude: /patternfly-4-cockpit.scss/,
|
|
use: [
|
|
extract.loader,
|
|
{
|
|
loader: 'css-loader',
|
|
options: {
|
|
sourceMap: true,
|
|
url: false
|
|
}
|
|
},
|
|
{
|
|
loader: 'sass-loader',
|
|
options: {
|
|
sourceMap: !production,
|
|
sassOptions: {
|
|
outputStyle: production ? 'compressed' : undefined,
|
|
},
|
|
},
|
|
},
|
|
]
|
|
},
|
|
]
|
|
},
|
|
plugins: plugins
|
|
}
|