h5p-interactive-video/webpack.config.js
2018-02-05 08:59:19 +01:00

51 lines
1.2 KiB
JavaScript

var path = require('path');
var nodeEnv = process.env.NODE_ENV || 'development';
var isDev = (nodeEnv !== 'production');
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const extractStyles = new ExtractTextPlugin({
filename: "h5p-interactive-video.css"
});
var config = {
entry: {
dist: './src/entries/dist.js'
},
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'h5p-interactive-video.js'
},
module: {
rules: [
{
test: /\.js$/,
loader: 'babel-loader'
},
{
test: /\.css$/,
include: path.resolve(__dirname, 'src'),
use: extractStyles.extract({
use: ["css-loader?sourceMap", "resolve-url-loader"],
fallback: "style-loader"
}),
},
{
test: /\.(eot|svg|ttf|woff|woff2)$/,
include: path.join(__dirname, 'src/fonts'),
loader: 'file-loader?name=fonts/[name].[ext]'
},
{
test: /\.(svg)$/,
include: path.join(__dirname, 'src/gui'),
loader: 'file-loader?name=fonts/[name].[ext]'
}
]
},
plugins: [extractStyles]
};
if(isDev) {
config.devtool = 'inline-source-map';
}
module.exports = config;