1
0
Fork 0
mirror of https://github.com/FrankerFaceZ/FrankerFaceZ.git synced 2025-06-27 21:05:53 +00:00
FrankerFaceZ/webpack.common.js

155 lines
3.1 KiB
JavaScript
Raw Normal View History

2017-11-13 01:23:39 -05:00
const webpack = require('webpack');
const path = require('path');
const semver = require('semver');
const VueLoaderPlugin = require('vue-loader/lib/plugin');
/* global process module __dirname */
const VERSION = semver.parse(require('./package.json').version);
const PRODUCTION = process.env.NODE_ENV === 'production';
const FOR_EXTENSION = !! process.env.FFZ_EXTENSION;
2017-11-13 01:23:39 -05:00
const ENTRY_POINTS = {
bridge: './src/bridge.js',
player: './src/player.js',
avalon: './src/main.js',
clips: './src/clips.js'
};
2017-11-13 01:23:39 -05:00
module.exports = {
entry: ENTRY_POINTS,
2017-11-13 01:23:39 -05:00
resolve: {
extensions: ['.js', '.jsx'],
2017-11-13 01:23:39 -05:00
alias: {
res: path.resolve(__dirname, 'res/'),
styles: path.resolve(__dirname, 'styles/'),
root: __dirname,
2017-11-13 01:23:39 -05:00
src: path.resolve(__dirname, 'src/'),
utilities: path.resolve(__dirname, 'src/utilities/')
}
},
externals: [
function(context, request, callback) {
if ( request === 'vue' && ! /utilities/.test(context) )
return callback(null, 'root ffzVue');
callback();
}
],
2017-11-13 01:23:39 -05:00
output: {
chunkFilename: FOR_EXTENSION
? '[name].js'
: '[name].[chunkhash].js',
2017-11-13 01:23:39 -05:00
path: path.resolve(__dirname, 'dist'),
jsonpFunction: 'ffzWebpackJsonp',
crossOriginLoading: 'anonymous'
2017-11-13 01:23:39 -05:00
},
optimization: {
splitChunks: {
chunks(chunk) {
return ! Object.keys(ENTRY_POINTS).includes(chunk.name);
},
cacheGroups: {
vendors: false
}
}
},
2017-11-13 01:23:39 -05:00
plugins: [
new VueLoaderPlugin(),
new webpack.ExtendedAPIPlugin(),
new webpack.DefinePlugin({
__version_major__: VERSION.major,
__version_minor__: VERSION.minor,
__version_patch__: VERSION.patch,
__version_prerelease__: VERSION.prerelease,
__extension__: FOR_EXTENSION
? JSON.stringify(process.env.FFZ_EXTENSION)
: false
}),
2017-11-13 01:23:39 -05:00
],
module: {
rules: [{
test: /\.s?css$/,
use: [{
loader: 'file-loader',
options: {
name: (! FOR_EXTENSION && PRODUCTION)
? '[name].[hash].css'
: '[name].css'
2017-11-13 01:23:39 -05:00
}
}, {
loader: 'extract-loader'
}, {
loader: 'css-loader',
options: {
sourceMap: true
}
}, {
loader: 'sass-loader',
options: {
sourceMap: true
}
}]
},
{
test: /\.json$/,
include: /src/,
type: 'javascript/auto',
loader: 'file-loader',
options: {
name: (! FOR_EXTENSION && PRODUCTION)
? '[name].[hash].json'
: '[name].json'
}
},
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
cacheDirectory: true
}
},
{
test: /\.jsx$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
cacheDirectory: true,
plugins: [
['@babel/plugin-transform-react-jsx', {
pragma: 'createElement'
}]
]
}
},
{
test: /\.(graphql|gql)$/,
exclude: /node_modules/,
loader: 'graphql-tag/loader'
},
2017-11-13 01:23:39 -05:00
{
test: /\.(?:otf|eot|ttf|woff|woff2)$/,
2017-11-13 01:23:39 -05:00
use: [{
loader: 'file-loader',
options: {
name: (! FOR_EXTENSION && PRODUCTION)
? '[name].[hash].[ext]'
: '[name].[ext]'
2017-11-13 01:23:39 -05:00
}
}]
},
{
test: /\.md$/,
loader: 'raw-loader'
},
2017-11-13 01:23:39 -05:00
{
test: /\.svg$/,
loader: 'raw-loader'
},
{
test: /\.vue$/,
loader: 'vue-loader'
}]
}
}