| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- const path = require('path');
- const webpack = require('webpack');
- const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin');
- const ExtractTextPlugin = require('extract-text-webpack-plugin');
- const HtmlWebpackPlugin = require('html-webpack-plugin');
- const utils = require('./utils');
- const vueLoaderConfig = require('./vue-loader.conf');
- process.env.NODE_ENV = process.env.NODE_ENV || 'development';
- const IS_DEV = process.env.NODE_ENV === 'development';
- const DIST = 'dist';
- const definePlugin = new webpack.DefinePlugin({
- 'process.env': {
- NODE_ENV: JSON.stringify(process.env.NODE_ENV),
- DEBUG: IS_DEV ? 'true' : 'false', // whether to log message errors
- },
- });
- function resolve(dir) {
- return path.join(__dirname, '..', dir);
- }
- const base = {
- output: {
- path: resolve(DIST),
- publicPath: '/',
- filename: '[name].js',
- },
- resolve: {
- extensions: ['.js', '.vue'],
- alias: {
- src: resolve('src'),
- }
- },
- module: {
- rules: [
- // {
- // test: /\.(js|vue)$/,
- // loader: 'eslint-loader',
- // enforce: 'pre',
- // include: [resolve('src'), resolve('test')],
- // options: {
- // formatter: require('eslint-friendly-formatter')
- // }
- // },
- {
- test: /\.vue$/,
- loader: 'vue-loader',
- options: vueLoaderConfig
- },
- {
- test: /\.js$/,
- loader: 'babel-loader',
- include: [resolve('src'), resolve('test')]
- },
- ].concat(utils.styleLoaders({
- sourceMap: false,
- extract: !IS_DEV,
- })),
- },
- // cheap-module-eval-source-map is faster for development
- devtool: IS_DEV ? '#inline-source-map' : false,
- };
- const targets = module.exports = [];
- targets.push(Object.assign({}, base, {
- entry: {
- 'background/app': 'src/background/app.js',
- 'options/app': 'src/options/app.js',
- 'popup/app': 'src/popup/app.js',
- },
- plugins: [
- definePlugin,
- // split vendor js into its own file
- new webpack.optimize.CommonsChunkPlugin({
- name: 'vendor',
- }),
- new HtmlWebpackPlugin({
- filename: 'background/index.html',
- template: 'src/background/index.html',
- inject: true,
- chunks: ['vendor', 'background/app'],
- chunksSortMode: 'dependency'
- }),
- new HtmlWebpackPlugin({
- filename: 'options/index.html',
- template: 'src/options/index.html',
- inject: true,
- chunks: ['vendor', 'options/app'],
- chunksSortMode: 'dependency'
- }),
- new HtmlWebpackPlugin({
- filename: 'popup/index.html',
- template: 'src/popup/index.html',
- inject: true,
- chunks: ['vendor', 'popup/app'],
- chunksSortMode: 'dependency'
- }),
- // new FriendlyErrorsPlugin(),
- ... IS_DEV ? [
- ] : [
- // extract css into its own file
- new ExtractTextPlugin('[name].css'),
- new webpack.optimize.UglifyJsPlugin({
- compress: {
- warnings: false
- }
- }),
- ],
- ],
- }));
- targets.push(Object.assign({}, base, {
- entry: {
- injected: 'src/injected.js',
- browser: 'src/browser.js',
- },
- plugins: [
- definePlugin,
- ... IS_DEV ? [] : [
- new webpack.optimize.UglifyJsPlugin({
- compress: {
- warnings: false
- }
- }),
- ],
- ],
- }));
|