163 lines
4.3 KiB
JavaScript
Raw Normal View History

2017-01-17 13:40:59 +01:00
/**
* COMMON WEBPACK CONFIGURATION
*/
const path = require('path');
2017-01-17 13:40:59 +01:00
const webpack = require('webpack');
const pkg = require(path.resolve(process.cwd(), 'package.json'));
const pluginId = pkg.name.replace(/^strapi-/i, '');
2017-01-17 13:40:59 +01:00
module.exports = (options) => ({
entry: options.entry,
output: Object.assign({ // Compile into js/build.js
2017-06-09 13:03:23 +01:00
path: path.resolve(process.cwd(), 'admin', 'build'),
2017-01-17 13:40:59 +01:00
publicPath: '/',
}, options.output), // Merge with env dependent settings
module: {
loaders: [{
test: /\.js$/, // Transform all .js files required somewhere with Babel
2017-05-16 16:32:54 +02:00
use: {
2017-08-18 17:51:10 +02:00
loader: 'babel-loader',
2017-05-16 16:32:54 +02:00
options: {
2017-07-21 17:18:47 +02:00
presets: options.babelPresets,
env: {
production: {
only: [
'src',
2017-05-16 16:32:54 +02:00
],
2017-07-21 17:18:47 +02:00
plugins: [
2017-05-17 11:21:03 +02:00
require.resolve('babel-plugin-transform-react-remove-prop-types'),
require.resolve('babel-plugin-transform-react-constant-elements'),
require.resolve('babel-plugin-transform-react-inline-elements'),
],
2017-05-16 16:32:54 +02:00
},
2017-07-21 17:18:47 +02:00
test: {
plugins: [
'istanbul',
],
},
},
2017-07-21 17:18:47 +02:00
},
2017-05-16 16:32:54 +02:00
},
include: [
2017-06-08 17:16:20 +01:00
path.join(process.cwd(), 'admin', 'src'),
2017-05-16 16:32:54 +02:00
// Add the `strapi-helper-plugin` folders watched by babel
2017-06-08 17:16:20 +01:00
path.join(process.cwd(), 'node_modules', 'strapi-helper-plugin', 'lib', 'src'),
2017-05-16 16:32:54 +02:00
],
2017-01-17 13:40:59 +01:00
}, {
2017-05-17 11:21:03 +02:00
// Transform our own .scss files
2017-01-17 13:40:59 +01:00
test: /\.scss$/,
use: [{
loader: 'style-loader',
}, {
loader: 'css-loader',
options: {
localIdentName: `${pluginId}[local]__[path][name]__[hash:base64:5]`,
modules: true,
importLoaders: 1,
sourceMap: true,
},
}, {
loader: 'postcss-loader',
options: {
config: {
path: path.resolve(__dirname, '..', 'postcss', 'postcss.config.js'),
},
},
}, {
loader: 'sass-loader',
}],
2017-01-17 13:40:59 +01:00
}, {
// Do not transform vendor's CSS with CSS-modules
// The point is that they remain in global scope.
// Since we require these CSS files in our JS or CSS files,
// they will be a part of our compilation either way.
// So, no need for ExtractTextPlugin here.
test: /\.css$/,
include: /node_modules/,
loaders: ['style-loader', 'css-loader'],
}, {
test: /\.(eot|svg|ttf|woff|woff2)$/,
loader: 'file-loader',
}, {
test: /\.(jpg|png|gif)$/,
loaders: [
'file-loader',
2017-08-18 17:51:10 +02:00
{
loader: 'image-webpack-loader',
query: {
mozjpeg: {
progressive: true,
},
gifsicle: {
interlaced: false,
},
optipng: {
optimizationLevel: 4,
},
pngquant: {
quality: '65-90',
speed: 4,
},
},
},
2017-01-17 13:40:59 +01:00
],
}, {
test: /\.html$/,
loader: 'html-loader',
2017-01-17 13:40:59 +01:00
}, {
test: /\.json$/,
loader: 'json-loader',
}, {
test: /\.(mp4|webm)$/,
loader: 'url-loader?limit=10000',
}],
},
plugins: options.plugins.concat([
new webpack.ProvidePlugin({
// make fetch available
2017-08-18 17:51:10 +02:00
fetch: 'exports-loader?self.fetch!whatwg-fetch',
2017-01-17 13:40:59 +01:00
}),
// Always expose NODE_ENV to webpack, in order to use `process.env.NODE_ENV`
// inside your code for any environment checks; UglifyJS will automatically
// drop any unreachable code.
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify(process.env.NODE_ENV),
},
}),
new webpack.NamedModulesPlugin(),
]),
resolve: {
2017-05-16 16:32:54 +02:00
modules: [
2017-06-08 17:16:20 +01:00
'admin/src',
'node_modules/strapi-helper-plugin/lib/src',
2017-05-16 16:32:54 +02:00
'node_modules/strapi-helper-plugin/node_modules',
'node_modules',
2017-05-16 16:32:54 +02:00
],
symlinks: false,
2017-01-17 13:40:59 +01:00
extensions: [
'.js',
'.jsx',
'.react.js',
],
mainFields: [
'browser',
'jsnext:main',
'main',
],
},
2017-05-16 16:32:54 +02:00
resolveLoader: {
modules: [
path.join(__dirname, '..', '..', '..', 'node_modules'),
path.join(process.cwd(), 'node_modules'),
],
2017-05-16 16:32:54 +02:00
},
2017-01-17 13:40:59 +01:00
devtool: options.devtool,
target: 'web', // Make web variables accessible to webpack, e.g. window
});