@ustack/uskin
Version:
A graceful framework which provides developers another chance to build an amazing site.
83 lines (78 loc) • 1.79 kB
JavaScript
var path = require('path');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var autoprefixer = require('autoprefixer');
var theme = process.env.npm_config_theme || 'default';
module.exports = {
entry: {
uskin: './js/uskin.js',
css: './css/uskin.less'
},
output: {
path: path.resolve(__dirname, './dist/js'),
filename: '[hash:6].[name].min.js',
library: 'uskin',
libraryTarget: 'umd'
},
externals: {
react: {
root: 'React',
commonjs2: 'react',
commonjs: 'react',
amd: 'react'
}
},
resolve: {
extensions: ['.js', '.jsx']
},
module: {
rules: [{
test: /\.js|jsx$/,
exclude: /node_modules|__tests__/,
use: {
loader: 'babel-loader',
options: {
cacheDirectory: process.env.NODE_ENV !== 'production'
}
}
}, {
test: /\.less$/,
use: ExtractTextPlugin.extract({
use: [{
loader: 'css-loader',
options: {
sourceMap: true,
minimize: ~process.argv.indexOf('--min')
}
}, {
loader: 'postcss-loader',
options: {
plugins: function() {
return [autoprefixer];
}
}
},
'less-loader?{sourceMap: true, modifyVars:{"theme": "\'' + theme + '\'"}}'
]
})
}, {
test: /\.(woff|svg|eot|ttf)$/,
use: [{
loader: 'url-loader',
options: {
limit: 1000,
name: './fonts/[hash:8].icon.[ext]'
}
}]
}, {
test: /\.(jpe?g|png|gif)$/i,
use: [{
loader: 'url-loader',
options: {
limit: 2000,
name: './img/[hash:8].[name].[ext]'
}
}]
}]
},
plugins: []
};