2017-11-13 01:23:39 -05:00
|
|
|
const webpack = require('webpack');
|
|
|
|
const path = require('path');
|
2019-06-20 17:14:03 -04:00
|
|
|
const semver = require('semver');
|
2018-03-15 16:59:10 -04:00
|
|
|
|
2019-06-19 20:57:14 -04:00
|
|
|
const VueLoaderPlugin = require('vue-loader/lib/plugin');
|
|
|
|
|
|
|
|
/* global process module __dirname */
|
|
|
|
|
2019-06-20 17:14:03 -04:00
|
|
|
const VERSION = semver.parse(require('./package.json').version);
|
2019-06-19 20:57:14 -04:00
|
|
|
const PRODUCTION = process.env.NODE_ENV === 'production';
|
2023-05-19 15:02:25 -04:00
|
|
|
const FOR_EXTENSION = !! process.env.FFZ_EXTENSION;
|
2017-11-13 01:23:39 -05:00
|
|
|
|
2021-03-02 16:55:25 -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 = {
|
2021-03-02 16:55:25 -05:00
|
|
|
entry: ENTRY_POINTS,
|
2017-11-13 01:23:39 -05:00
|
|
|
resolve: {
|
2018-04-01 18:24:08 -04:00
|
|
|
extensions: ['.js', '.jsx'],
|
2017-11-13 01:23:39 -05:00
|
|
|
alias: {
|
|
|
|
res: path.resolve(__dirname, 'res/'),
|
|
|
|
styles: path.resolve(__dirname, 'styles/'),
|
2018-04-11 22:18:04 -04:00
|
|
|
root: __dirname,
|
2017-11-13 01:23:39 -05:00
|
|
|
src: path.resolve(__dirname, 'src/'),
|
|
|
|
utilities: path.resolve(__dirname, 'src/utilities/')
|
|
|
|
}
|
|
|
|
},
|
2018-04-05 15:44:47 -04:00
|
|
|
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: {
|
2023-05-19 15:02:25 -04:00
|
|
|
chunkFilename: FOR_EXTENSION
|
|
|
|
? '[name].js'
|
|
|
|
: '[name].[chunkhash].js',
|
2017-11-13 01:23:39 -05:00
|
|
|
path: path.resolve(__dirname, 'dist'),
|
2018-04-15 17:19:22 -04:00
|
|
|
jsonpFunction: 'ffzWebpackJsonp',
|
|
|
|
crossOriginLoading: 'anonymous'
|
2017-11-13 01:23:39 -05:00
|
|
|
},
|
2019-06-19 20:57:14 -04:00
|
|
|
optimization: {
|
|
|
|
splitChunks: {
|
2021-02-11 19:40:12 -05:00
|
|
|
chunks(chunk) {
|
2021-03-02 16:55:25 -05:00
|
|
|
return ! Object.keys(ENTRY_POINTS).includes(chunk.name);
|
2021-02-11 19:40:12 -05:00
|
|
|
},
|
2019-06-19 20:57:14 -04:00
|
|
|
cacheGroups: {
|
|
|
|
vendors: false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2017-11-13 01:23:39 -05:00
|
|
|
plugins: [
|
2019-06-19 20:57:14 -04:00
|
|
|
new VueLoaderPlugin(),
|
2019-06-20 17:14:03 -04:00
|
|
|
new webpack.ExtendedAPIPlugin(),
|
|
|
|
new webpack.DefinePlugin({
|
|
|
|
__version_major__: VERSION.major,
|
|
|
|
__version_minor__: VERSION.minor,
|
|
|
|
__version_patch__: VERSION.patch,
|
2023-05-19 15:02:25 -04:00
|
|
|
__version_prerelease__: VERSION.prerelease,
|
|
|
|
__extension__: FOR_EXTENSION
|
|
|
|
? JSON.stringify(process.env.FFZ_EXTENSION)
|
|
|
|
: false
|
2019-06-20 17:14:03 -04:00
|
|
|
}),
|
2017-11-13 01:23:39 -05:00
|
|
|
],
|
|
|
|
module: {
|
|
|
|
rules: [{
|
|
|
|
test: /\.s?css$/,
|
|
|
|
use: [{
|
|
|
|
loader: 'file-loader',
|
|
|
|
options: {
|
2023-05-19 15:02:25 -04:00
|
|
|
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
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
},
|
2019-06-19 20:57:14 -04:00
|
|
|
{
|
|
|
|
test: /\.json$/,
|
|
|
|
include: /src/,
|
|
|
|
type: 'javascript/auto',
|
|
|
|
loader: 'file-loader',
|
|
|
|
options: {
|
2023-05-19 15:02:25 -04:00
|
|
|
name: (! FOR_EXTENSION && PRODUCTION)
|
|
|
|
? '[name].[hash].json'
|
|
|
|
: '[name].json'
|
2019-06-19 20:57:14 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.js$/,
|
|
|
|
exclude: /node_modules/,
|
|
|
|
loader: 'babel-loader',
|
|
|
|
options: {
|
|
|
|
cacheDirectory: true
|
|
|
|
}
|
|
|
|
},
|
2018-04-01 18:24:08 -04:00
|
|
|
{
|
|
|
|
test: /\.jsx$/,
|
|
|
|
exclude: /node_modules/,
|
2019-06-19 20:57:14 -04:00
|
|
|
loader: 'babel-loader',
|
|
|
|
options: {
|
|
|
|
cacheDirectory: true,
|
|
|
|
plugins: [
|
|
|
|
['@babel/plugin-transform-react-jsx', {
|
|
|
|
pragma: 'createElement'
|
|
|
|
}]
|
|
|
|
]
|
|
|
|
}
|
2018-04-01 18:24:08 -04:00
|
|
|
},
|
2018-02-22 18:23:44 -05:00
|
|
|
{
|
|
|
|
test: /\.(graphql|gql)$/,
|
|
|
|
exclude: /node_modules/,
|
|
|
|
loader: 'graphql-tag/loader'
|
|
|
|
},
|
2017-11-13 01:23:39 -05:00
|
|
|
{
|
2021-09-06 16:48:48 -04:00
|
|
|
test: /\.(?:otf|eot|ttf|woff|woff2)$/,
|
2017-11-13 01:23:39 -05:00
|
|
|
use: [{
|
|
|
|
loader: 'file-loader',
|
|
|
|
options: {
|
2023-05-19 15:02:25 -04:00
|
|
|
name: (! FOR_EXTENSION && PRODUCTION)
|
|
|
|
? '[name].[hash].[ext]'
|
|
|
|
: '[name].[ext]'
|
2017-11-13 01:23:39 -05:00
|
|
|
}
|
|
|
|
}]
|
|
|
|
},
|
2019-05-03 19:30:46 -04:00
|
|
|
{
|
|
|
|
test: /\.md$/,
|
|
|
|
loader: 'raw-loader'
|
|
|
|
},
|
2017-11-13 01:23:39 -05:00
|
|
|
{
|
|
|
|
test: /\.svg$/,
|
|
|
|
loader: 'raw-loader'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.vue$/,
|
|
|
|
loader: 'vue-loader'
|
|
|
|
}]
|
|
|
|
}
|
|
|
|
}
|