-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.prod.js
106 lines (99 loc) · 3 KB
/
webpack.prod.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
const webpack = require('webpack');
const path = require('path');
//const UglifyJsPlugin = require('uglifyjs-webpack-plugin'); // no support for ES6+
const TerserPlugin = require('terser-webpack-plugin'); // support for ES6+ (succesor of uglify-es)
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CopyPlugin = require('copy-webpack-plugin');
module.exports = {
node: false,
node: {
fs: 'empty'
},
mode: 'production',
// devtool:
// devServer: {
// //contentBase: path.join(__dirname, 'demo'),
// //compress: true,
// port: 8889,
// writeToDisk: false,
// },
performance: {
hints: false,
},
target: 'web',
context: path.resolve(__dirname, 'src'),
optimization: {
minimize: true,
minimizer: [
new TerserPlugin({
cache: false,
//test: /\.js(\?.*)?$/i,
test: /\.min\.js$/
}),
],
},
entry: {
//'ractive-window': path.resolve(__dirname, './src/index.js'),
'ractive-window.min': path.resolve(__dirname, './src/index.js')
},
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
library: 'RactiveWindow',
// var, this, window, umd , amd, commonjs, global
libraryTarget: 'umd',
umdNamedDefine: true, // Important
libraryExport: 'default',
globalObject: 'this',
},
externals: {
ractive: {
commonjs: 'ractive', // require
commonjs2: 'ractive', // require + module.exports - used by nodejs
amd: 'ractive',
root: 'Ractive'
},
},
plugins: [
new MiniCssExtractPlugin({ filename: "[name].css" }), // { filename: "[name].[contentHash].css" }
new CopyPlugin([
{ from: 'css/theme.less', to: 'less/theme.less' },
{ from: 'css/common.less', to: 'less/common.less' },
{ from: 'css/theme-windows.less', to: 'less/theme-windows.less' },
{ from: 'css/theme-atom.less', to: 'less/theme-atom.less' },
{ from: 'css/theme-atomdark.less', to: 'less/theme-atomdark.less' },
{ from: 'css/theme-atomlight.less', to: 'less/theme-atomlight.less' },
{ from: 'css/theme-atom/one-dark-ui/ui-variables-custom.less', to: 'less/theme-atom/one-dark-ui/ui-variables-custom.less' },
{ from: 'css/theme-atom/one-dark-ui/ui-variables.less', to: 'less/theme-atom/one-dark-ui/ui-variables.less' },
{ from: 'css/theme-atom/one-light-ui/ui-variables-custom.less', to: 'less/theme-atom/one-light-ui/ui-variables-custom.less' },
{ from: 'css/theme-atom/one-light-ui/ui-variables.less', to: 'less/theme-atom/one-light-ui/ui-variables.less' },
{ from: 'css/theme-aws.less', to: 'less/theme-aws.less' },
]),
],
module: {
rules: [
{
test: /\.less$/,
use: [
MiniCssExtractPlugin.loader, // extract css into files
{
loader: 'css-loader', // translates CSS into CommonJS
},
{
loader: 'less-loader', // compiles Less to CSS
// options: {
// paths: [path.resolve(__dirname, 'node_modules')],
// strictMath: true,
// noIeCompat: true,
// },
},
],
},
{
test: /\.js$/,
exclude: /(node_modules|bower_components)/,
use: 'babel-loader'
}
]
}
}