mirror of https://github.com/ElemeFE/element
				
				
				
			
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
| const path = require('path');
 | |
| const webpack = require('webpack');
 | |
| const ProgressBarPlugin = require('progress-bar-webpack-plugin');
 | |
| 
 | |
| const Components = require('../components.json');
 | |
| const config = require('./config');
 | |
| 
 | |
| const webpackConfig = {
 | |
|   entry: Components,
 | |
|   output: {
 | |
|     path: path.resolve(process.cwd(), './lib'),
 | |
|     publicPath: '/dist/',
 | |
|     filename: '[name].js',
 | |
|     chunkFilename: '[id].js',
 | |
|     libraryTarget: 'commonjs2'
 | |
|   },
 | |
|   resolve: {
 | |
|     extensions: ['.js', '.vue', '.json'],
 | |
|     alias: config.alias,
 | |
|     modules: ['node_modules']
 | |
|   },
 | |
|   externals: config.externals,
 | |
|   module: {
 | |
|     rules: [
 | |
|       {
 | |
|         test: /\.(jsx?|babel|es6)$/,
 | |
|         include: process.cwd(),
 | |
|         exclude: config.jsexclude,
 | |
|         loader: 'babel-loader'
 | |
|       },
 | |
|       {
 | |
|         test: /\.vue$/,
 | |
|         loader: 'vue-loader',
 | |
|         options: {
 | |
|           preserveWhitespace: false
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         test: /\.json$/,
 | |
|         loader: 'json-loader'
 | |
|       },
 | |
|       {
 | |
|         test: /\.css$/,
 | |
|         loaders: ['style-loader', 'css-loader', 'postcss-loader']
 | |
|       },
 | |
|       {
 | |
|         test: /\.scss$/,
 | |
|         loaders: ['style-loader', 'css-loader', 'sass-loader']
 | |
|       },
 | |
|       {
 | |
|         test: /\.html$/,
 | |
|         loader: 'html-loader?minimize=false'
 | |
|       },
 | |
|       {
 | |
|         test: /\.otf|ttf|woff2?|eot(\?\S*)?$/,
 | |
|         loader: 'url-loader',
 | |
|         query: {
 | |
|           limit: 10000,
 | |
|           name: path.posix.join('static', '[name].[hash:7].[ext]')
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         test: /\.svg(\?\S*)?$/,
 | |
|         loader: 'url-loader',
 | |
|         query: {
 | |
|           limit: 10000,
 | |
|           name: path.posix.join('static', '[name].[hash:7].[ext]')
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         test: /\.(gif|png|jpe?g)(\?\S*)?$/,
 | |
|         loader: 'url-loader',
 | |
|         query: {
 | |
|           limit: 10000,
 | |
|           name: path.posix.join('static', '[name].[hash:7].[ext]')
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   },
 | |
|   plugins: [
 | |
|     new ProgressBarPlugin(),
 | |
|     new webpack.DefinePlugin({
 | |
|       'process.env.NODE_ENV': JSON.stringify('production')
 | |
|     }),
 | |
|     new webpack.LoaderOptionsPlugin({
 | |
|       minimize: true
 | |
|     })
 | |
|   ]
 | |
| };
 | |
| 
 | |
| module.exports = webpackConfig;
 |