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
| const pkg = require('./package.json');
| const path = require('path');
| const webpack = require('webpack');
| const UglifyJSPlugin = require('uglifyjs-webpack-plugin');
|
| const production = process.env.NODE_ENV === 'production' || false;
|
| const banner = `clipboard.js v${pkg.version}
| https://zenorocha.github.io/clipboard.js
|
| Licensed MIT © Zeno Rocha`;
|
| module.exports = {
| entry: './src/clipboard.js',
| mode: 'production',
| output: {
| filename: production ? 'clipboard.min.js' : 'clipboard.js',
| path: path.resolve(__dirname, 'dist'),
| library: 'ClipboardJS',
| libraryTarget: 'umd',
| globalObject: 'this'
| },
| module: {
| rules: [
| {test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader'}
| ]
| },
| optimization: {
| minimize: production,
| minimizer: [
| new UglifyJSPlugin({
| parallel: require('os').cpus().length,
| uglifyOptions: {
| ie8: false,
| keep_fnames: false,
| output: {
| beautify: false,
| comments: (node, {value, type}) => type == 'comment2' && value.startsWith('!')
| }
| }
| })
| ]
| },
| plugins: [new webpack.BannerPlugin({ banner })]
| };
|
|