const webpack = require("webpack"); const MiniCssExtractPlugin = require("mini-css-extract-plugin"); const path = require("path"); /** * Webpack configuration details for use with Grunt. * * @author n1474335 [n1474335@gmail.com] * @copyright Crown Copyright 2017 * @license Apache-2.0 */ const banner = `/** * CyberChef - The Cyber Swiss Army Knife * * @copyright Crown Copyright 2016 * @license Apache-2.0 * * Copyright 2016 Crown Copyright * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */`; // const vendorCSS = new MiniCssExtractPlugin({ // filename: "[name].css", // }); // const projectCSS = new MiniCssExtractPlugin({ // filename: "styles.css", // chunkFileName: "styles.css", // }); module.exports = { plugins: [ new webpack.ProvidePlugin({ $: "jquery", jQuery: "jquery", log: "loglevel" }), new webpack.BannerPlugin({ banner: banner, raw: true, entryOnly: true }), new webpack.DefinePlugin({ "process.browser": "true" }), new MiniCssExtractPlugin({ filename: "[name].css", chunkFilename: "[id].css", }), ], resolve: { alias: { jquery: "jquery/src/jquery" } }, // optimization: { // splitChunks: { // cacheGroups: { // styles: { // name: "styles", // test: /\.css$/, // // test: (module,c,entry = 'foo') => module.constructor.name === 'CssModule' && recursiveIssuer(m) === entry, // chunks: "all", // enforce: true // }, // vendor: { // name: "vendor", // test: /\.scss$/, // chunks: "all", // enforce: true, // }, // } // } // }, module: { rules: [ { test: /\.m?js$/, exclude: /node_modules\/(?!jsesc|crypto-api)/, options: { configFile: path.resolve(__dirname, "babel.config.js"), cacheDirectory: true, compact: false }, type: "javascript/auto", loader: "babel-loader" }, { test: /forge.min.js$/, loader: "imports-loader?jQuery=>null" }, { test: /bootstrap-material-design/, loader: "imports-loader?Popper=popper.js/dist/umd/popper.js" }, { test: /\.css$/, use: [ MiniCssExtractPlugin.loader, "css-loader", "postcss-loader", ] // use: projectCSS.extract({ // use: [ // { loader: "css-loader" }, // { loader: "postcss-loader" }, // ] // }) }, { test: /\.scss$/, use: [ MiniCssExtractPlugin.loader, "css-loader", "sass-loader", ] // use: vendorCSS.extract({ // use: [ // { loader: "css-loader" }, // { loader: "sass-loader" } // ] // }) }, { test: /\.(ico|eot|ttf|woff|woff2)$/, loader: "url-loader", options: { limit: 10000 } }, { // First party images are saved as files to be cached test: /\.(png|jpg|gif|svg)$/, exclude: /node_modules/, loader: "file-loader", options: { name: "images/[name].[ext]" } }, { // Third party images are inlined test: /\.(png|jpg|gif|svg)$/, exclude: /web\/static/, loader: "url-loader", options: { limit: 10000 } }, ] }, stats: { children: false, chunks: false, modules: false, entrypoints: false, warningsFilter: [ /source-map/, /dependency is an expression/, /export 'default'/ ], }, node: { fs: "empty" }, performance: { hints: false } };