-
Notifications
You must be signed in to change notification settings - Fork 23
/
webpack.config.base.babel.js
114 lines (113 loc) · 3.37 KB
/
webpack.config.base.babel.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import { VueLoaderPlugin } from 'vue-loader'
import CleanWebpackPlugin from 'clean-webpack-plugin'
import HtmlWebpackPlugin from 'html-webpack-plugin'
import CopyWebpackPlugin from 'copy-webpack-plugin'
import path from 'path'
import ImageminPlugin from 'imagemin-webpack-plugin'
import ExtractTextPlugin from 'extract-text-webpack-plugin'
export const resolve = (...paths) => path.join(__dirname, ...paths);
export const base = {
entry: {
main: resolve('vue', 'browser-action.js'),
welcome: resolve('welcome', 'welcome.js')
},
output: {
path: resolve('build'),
filename : '[name].bundle.js',
},
module: {
rules: [
{
test: /\.vue$/,
use: 'vue-loader'
},
{
test: /\.(eot|ttf|woff|woff2)$/,
loader: 'file-loader?name=public/fonts/[name].[ext]'
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract({
use: 'css-loader',
fallback: 'vue-style-loader'
})
},
{
test: /\.scss$/,
use: ExtractTextPlugin.extract({
use: [
'css-loader',
{
loader: 'sass-loader',
options: {
data: '@import "variables";',
includePaths: [
resolve('vue', 'scss'),
resolve('vue')
]
}
}
],
fallback: 'vue-style-loader'
}),
},
{
test: /\.(png|jpe?g|gif|svg)$/,
loader: 'svg-url-loader',
options: {
fallback: 'file-loader',
limit: 2 * 1024,
noquotes: true,
outputPath: 'images'
}
}
]
},
resolve: {
alias: {
'@': resolve('vue'),
'$vendor': resolve('node_modules'),
'@welcome': resolve('welcome')
}
},
plugins: [
new CleanWebpackPlugin(["build"]),
new VueLoaderPlugin(),
new ExtractTextPlugin({
allChunks: true,
filename: '[name].[chunkhash].css'
}),
new CopyWebpackPlugin([
{
from: "data",
to: "data"
},
{
from: "_locales",
to: "_locales"
},
{
from: 'addon',
to: 'addon'
},
{
from: "background.html"
},
{
from: 'prompt'
}
]),
new HtmlWebpackPlugin({
template: resolve('vue', 'templates', 'browser-action.html'),
filename: "browser-action.html",
chunks: ['main']
}),
new HtmlWebpackPlugin({
template: resolve('welcome', 'index.html'),
filename: 'welcome.html',
chunks: ['welcome']
}),
new ImageminPlugin({ test: /\.(jpe?g|png|gif|svg)$/i })
],
mode: 'production'
};