fchat-rising/mobile/webpack.config.js

64 lines
2.2 KiB
JavaScript

const path = require('path');
const ForkTsCheckerWebpackPlugin = require('@f-list/fork-ts-checker-webpack-plugin');
const VueLoaderPlugin = require('vue-loader/lib/plugin');
const vueTransformer = require('@f-list/vue-ts/transform').default;
const config = {
entry: {
chat: [__dirname + '/chat.ts', __dirname + '/index.html']
},
output: {
path: __dirname + '/www',
filename: '[name].js'
},
context: __dirname,
module: {
rules: [
{
test: /\.ts$/,
loader: 'ts-loader',
options: {
appendTsSuffixTo: [/\.vue$/],
configFile: __dirname + '/tsconfig.json',
transpileOnly: true,
getCustomTransformers: () => ({before: [vueTransformer]})
}
},
{
test: /\.vue$/,
loader: 'vue-loader',
options: {
compilerOptions: {
preserveWhitespace: false
}
}
},
{test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, loader: 'file-loader'},
{test: /\.(woff2?)$/, loader: 'file-loader'},
{test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/, loader: 'file-loader'},
{test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'file-loader'},
{test: /\.(wav|mp3|ogg)$/, loader: 'file-loader?name=sounds/[name].[ext]'},
{test: /\.(png|html)$/, loader: 'file-loader?name=[name].[ext]'},
{test: /(?<!\.vue)\.scss/, use: ['css-loader', 'sass-loader']},
{test: /\.vue\.scss/, loader: ['vue-style-loader','css-loader','sass-loader']},
{test: /\.vue\.css/, loader: ['vue-style-loader','css-loader']},
]
},
plugins: [
new ForkTsCheckerWebpackPlugin({workers: 2, async: false, vue: true, tslint: path.join(__dirname, '../tslint.json')}),
new VueLoaderPlugin()
],
resolve: {
'extensions': ['.ts', '.js', '.vue', '.scss']
}
};
module.exports = function(mode) {
if(mode === 'production') {
process.env.NODE_ENV = 'production';
config.devtool = 'source-map';
} else {
config.devtool = 'none';
}
return config;
};