Blame webpack.config.js

Packit Service 0246ed
const path = require("path");
Packit Service 0246ed
const webpack = require("webpack");
Packit Service 0246ed
const CopyWebpackPlugin = require("copy-webpack-plugin");
Packit Service 0246ed
const HtmlWebpackPlugin = require("html-webpack-plugin");
Packit Service 0246ed
const CleanWebpackPlugin = require("clean-webpack-plugin");
Packit Service 0246ed
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
Packit Service 0246ed
const babelConfig = require("./babel.config");
Packit Service 0246ed
Packit Service 0246ed
const nodedir = path.resolve(process.env.SRCDIR || __dirname, "node_modules");
Packit Service 0246ed
Packit Service 0246ed
const [mode, devtool] =
Packit Service 0246ed
  process.env.NODE_ENV === "production" ? ["production", "source-map"] : ["development", "inline-source-map"];
Packit Service 0246ed
Packit Service 0246ed
const output = {
Packit Service 0246ed
  path: path.resolve(__dirname, "./public/dist"),
Packit Service 0246ed
  filename: "[name].js",
Packit Service 0246ed
  sourceMapFilename: "[file].map",
Packit Service 0246ed
};
Packit Service 0246ed
Packit Service 0246ed
// add istanbul as babel plugin to enable code coverage
Packit Service 0246ed
process.argv.includes("--with-coverage") && babelConfig.plugins.push("istanbul");
Packit Service 0246ed
Packit Service 0246ed
const plugins = [
Packit Service 0246ed
  new CleanWebpackPlugin(["public/dist"]),
Packit Service 0246ed
  // automatically load jquery instead of having to import or require them everywhere
Packit Service 0246ed
  new webpack.ProvidePlugin({
Packit Service 0246ed
    $: "jquery",
Packit Service 0246ed
    jQuery: "jquery",
Packit Service 0246ed
  }),
Packit Service 0246ed
  // copy our assets
Packit Service 0246ed
  new CopyWebpackPlugin([
Packit Service 0246ed
    {
Packit Service 0246ed
      from: "./public/manifest.json",
Packit Service 0246ed
    },
Packit Service 0246ed
  ]),
Packit Service 0246ed
  // main.js has to be injected into body and after 
Packit Service 0246ed
  new HtmlWebpackPlugin({
Packit Service 0246ed
    filename: "index.html",
Packit Service 0246ed
    template: "public/index.ejs",
Packit Service 0246ed
    inject: "body",
Packit Service 0246ed
  }),
Packit Service 0246ed
  // avoid multi chunks for every index.js inside pages folder
Packit Service 0246ed
  new webpack.optimize.LimitChunkCountPlugin({
Packit Service 0246ed
    maxChunks: 1,
Packit Service 0246ed
  }),
Packit Service 0246ed
  new MiniCssExtractPlugin({
Packit Service 0246ed
    filename: "[name].css",
Packit Service 0246ed
    chunkFilename: "[name].bundle.css",
Packit Service 0246ed
  }),
Packit Service 0246ed
];
Packit Service 0246ed
Packit Service 0246ed
module.exports = {
Packit Service 0246ed
  mode,
Packit Service 0246ed
  entry: "./main.js",
Packit Service 0246ed
  plugins,
Packit Service 0246ed
  output,
Packit Service 0246ed
  devtool,
Packit Service 0246ed
  externals: { cockpit: "cockpit", jQuery: "jquery" },
Packit Service 0246ed
  // disable noisy warnings about exceeding the recommended size limit
Packit Service 0246ed
  performance: {
Packit Service 0246ed
    maxEntrypointSize: 20000000,
Packit Service 0246ed
    maxAssetSize: 20000000,
Packit Service 0246ed
  },
Packit Service 0246ed
  resolve: { alias: { "font-awesome": path.resolve(nodedir, "font-awesome-sass/assets/stylesheets") } },
Packit Service 0246ed
  module: {
Packit Service 0246ed
    rules: [
Packit Service 0246ed
      {
Packit Service 0246ed
        enforce: "pre",
Packit Service 0246ed
        test: /\.(js|jsx)$/,
Packit Service 0246ed
        exclude: [/node_modules/, /build/],
Packit Service 0246ed
        use: "eslint-loader",
Packit Service 0246ed
      },
Packit Service 0246ed
      {
Packit Service 0246ed
        test: /\.(js|jsx)$/,
Packit Service 0246ed
        include: [
Packit Service 0246ed
          path.resolve(__dirname, "./actions"),
Packit Service 0246ed
          path.resolve(__dirname, "./components"),
Packit Service 0246ed
          path.resolve(__dirname, "./core"),
Packit Service 0246ed
          path.resolve(__dirname, "./pages"),
Packit Service 0246ed
          path.resolve(__dirname, "./data"),
Packit Service 0246ed
          path.resolve(__dirname, "./main.js"),
Packit Service 0246ed
        ],
Packit Service 0246ed
        use: {
Packit Service 0246ed
          loader: "babel-loader",
Packit Service 0246ed
          options: babelConfig,
Packit Service 0246ed
        },
Packit Service 0246ed
      },
Packit Service 0246ed
      // add type: "javascript/auto" when transforming JSON via loader to JS
Packit Service 0246ed
      {
Packit Service 0246ed
        include: [path.resolve(__dirname, "./routes.json")],
Packit Service 0246ed
        use: [
Packit Service 0246ed
          {
Packit Service 0246ed
            loader: "babel-loader",
Packit Service 0246ed
            options: babelConfig,
Packit Service 0246ed
          },
Packit Service 0246ed
          path.resolve(__dirname, "./utils/routes-loader.js"),
Packit Service 0246ed
        ],
Packit Service 0246ed
        type: "javascript/auto",
Packit Service 0246ed
      },
Packit Service 0246ed
      {
Packit Service 0246ed
        test: /\.css$/,
Packit Service 0246ed
        use: [
Packit Service 0246ed
          MiniCssExtractPlugin.loader,
Packit Service 0246ed
          {
Packit Service 0246ed
            loader: "css-loader",
Packit Service 0246ed
            options: { url: false },
Packit Service 0246ed
          },
Packit Service 0246ed
        ],
Packit Service 0246ed
      },
Packit Service 0246ed
      /* HACK: remove unwanted fonts from PatternFly's css */
Packit Service 0246ed
      {
Packit Service 0246ed
        test: /patternfly-cockpit.scss$/,
Packit Service 0246ed
        use: [
Packit Service 0246ed
          MiniCssExtractPlugin.loader,
Packit Service 0246ed
          {
Packit Service 0246ed
            loader: "css-loader",
Packit Service 0246ed
            options: { url: false },
Packit Service 0246ed
          },
Packit Service 0246ed
          {
Packit Service 0246ed
            loader: "string-replace-loader",
Packit Service 0246ed
            options: {
Packit Service 0246ed
              multiple: [
Packit Service 0246ed
                {
Packit Service 0246ed
                  search: /src:url[(]"patternfly-icons-fake-path\/glyphicons-halflings-regular[^}]*/g,
Packit Service 0246ed
                  replace: 'font-display:block; src:url("../base1/fonts/glyphicons.woff") format("woff");',
Packit Service 0246ed
                },
Packit Service 0246ed
                {
Packit Service 0246ed
                  search: /src:url[(]"patternfly-fonts-fake-path\/PatternFlyIcons[^}]*/g,
Packit Service 0246ed
                  replace: 'src:url("../base1/fonts/patternfly.woff") format("woff");',
Packit Service 0246ed
                },
Packit Service 0246ed
                {
Packit Service 0246ed
                  search: /src:url[(]"patternfly-fonts-fake-path\/fontawesome[^}]*/,
Packit Service 0246ed
                  replace: 'font-display:block; src:url("../base1/fonts/fontawesome.woff?v=4.2.0") format("woff");',
Packit Service 0246ed
                },
Packit Service 0246ed
                {
Packit Service 0246ed
                  search: /src:url\("patternfly-icons-fake-path\/pficon[^}]*/g,
Packit Service 0246ed
                  replace: 'src:url("../base1/fonts/patternfly.woff") format("woff");',
Packit Service 0246ed
                },
Packit Service 0246ed
                {
Packit Service 0246ed
                  search: /@font-face[^}]*patternfly-fonts-fake-path[^}]*}/g,
Packit Service 0246ed
                  replace: "",
Packit Service 0246ed
                },
Packit Service 0246ed
              ],
Packit Service 0246ed
            },
Packit Service 0246ed
          },
Packit Service 0246ed
          {
Packit Service 0246ed
            loader: "sass-loader",
Packit Service 0246ed
            options: {
Packit Service 0246ed
              sassOptions: {
Packit Service 0246ed
                includePaths: [
Packit Service 0246ed
                  // Teach webpack to resolve these references in order to build PF3 scss
Packit Service 0246ed
                  path.resolve(nodedir, "font-awesome-sass", "assets", "stylesheets"),
Packit Service 0246ed
                  path.resolve(nodedir, "patternfly", "dist", "sass"),
Packit Service 0246ed
                  path.resolve(nodedir, "bootstrap-sass", "assets", "stylesheets"),
Packit Service 0246ed
                ],
Packit Service 0246ed
                outputStyle: "compressed",
Packit Service 0246ed
              },
Packit Service 0246ed
            },
Packit Service 0246ed
          },
Packit Service 0246ed
        ],
Packit Service 0246ed
      },
Packit Service 0246ed
    ],
Packit Service 0246ed
  },
Packit Service 0246ed
};