m-vue-aplayer
Version:
Easy-to-use music player for Vue 2.x
90 lines (86 loc) • 2 kB
JavaScript
var path = require('path')
var webpack = require('webpack')
module.exports = {
entry: './src/vue-aplayer.vue',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'vue-aplayer.min.js',
library: 'VueAPlayer',
libraryTarget: 'umd',
libraryExport: 'default',
umdNamedDefine: true
},
externals: {
'hls.js': {
amd: 'hls.js',
commonjs: 'hls.js',
commonjs2: 'hls.js',
root: 'Hls'
},
'vue': {
amd: 'vue',
commonjs: 'vue',
commonjs2: 'vue',
root: 'Vue'
},
},
module: {
rules: [
{
test: /\.(js|vue)$/,
loader: 'eslint-loader',
enforce: 'pre',
include: [path.resolve(__dirname, 'src')],
options: {
formatter: require('eslint-friendly-formatter'),
emitWarning: true
}
},
{
test: /\.vue$/,
loader: 'vue-loader',
options: {
loaders: {
scss: 'vue-style-loader!css-loader?minimize=true!postcss-loader!sass-loader'
},
}
},
{
test: /\.js$/,
loader: 'babel-loader',
exclude: /node_modules/,
},
{
test: /\.(png|jpg)$/,
loader: 'url-loader?limit=40000'
},
{
test: /\.svg$/,
loader: 'svg-inline-loader'
},
{
test: /\.html$/,
loader: 'vue-html-loader'
}
]
},
devtool: '#source-map',
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: `"${process.env.NODE_ENV}"`
},
VERSION: JSON.stringify(require('./package.json').version)
}),
]
}
if (process.env.NODE_ENV === 'production') {
// http://vuejs.github.io/vue-loader/workflow/production.html
module.exports.plugins.push(
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
},
})
)
}