diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /browser/components/newtab/webpack.system-addon.config.js | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.zip |
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'browser/components/newtab/webpack.system-addon.config.js')
-rw-r--r-- | browser/components/newtab/webpack.system-addon.config.js | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/browser/components/newtab/webpack.system-addon.config.js b/browser/components/newtab/webpack.system-addon.config.js new file mode 100644 index 0000000000..8c45af2d3a --- /dev/null +++ b/browser/components/newtab/webpack.system-addon.config.js @@ -0,0 +1,75 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this file, + * You can obtain one at http://mozilla.org/MPL/2.0/. */ + +const path = require("path"); +const webpack = require("webpack"); + +const absolute = relPath => path.join(__dirname, relPath); + +const resourcePathRegEx = /^resource:\/\/activity-stream\//; + +module.exports = (env = {}) => ({ + mode: "none", + entry: absolute("content-src/activity-stream.jsx"), + output: { + path: absolute("data/content"), + filename: "activity-stream.bundle.js", + library: "NewtabRenderUtils", + }, + // TODO: switch to eval-source-map for faster builds. Requires CSP changes + devtool: env.development ? "inline-source-map" : false, + plugins: [ + new webpack.BannerPlugin( + `THIS FILE IS AUTO-GENERATED: ${path.basename(__filename)}` + ), + new webpack.optimize.ModuleConcatenationPlugin(), + ], + module: { + rules: [ + { + test: /\.jsx?$/, + exclude: /node_modules\/(?!(fluent|fluent-react)\/).*/, + loader: "babel-loader", + options: { + presets: ["@babel/preset-react"], + plugins: ["@babel/plugin-proposal-optional-chaining"], + }, + }, + { + test: /\.jsm$/, + exclude: /node_modules/, + loader: "babel-loader", + // Converts .jsm files into common-js modules + options: { + plugins: [ + [ + "./tools/babel-jsm-to-commonjs.js", + { + basePath: resourcePathRegEx, + removeOtherImports: true, + replace: true, + }, + ], + ], + }, + }, + ], + }, + // This resolve config allows us to import with paths relative to the root directory, e.g. "lib/ActivityStream.jsm" + resolve: { + extensions: [".js", ".jsx"], + modules: ["node_modules", "."], + fallback: { + stream: require.resolve("stream-browserify"), + }, + }, + externals: { + "prop-types": "PropTypes", + react: "React", + "react-dom": "ReactDOM", + redux: "Redux", + "react-redux": "ReactRedux", + "react-transition-group": "ReactTransitionGroup", + }, +}); |