html-webpack-url-plugin
v1.0.1
Published
Instead of html template provide a URL for your template
Downloads
88
Readme
html-webpack-url-plugin
Instead of html template file provide the template URL
Example
const path = require('path'),
HtmlWebpackPlugin = require('html-webpack-plugin'),
ExtractTextPlugin = require('extract-text-webpack-plugin'),
UglifyJsPlugin = require('uglifyjs-webpack-plugin'),
CopyWebpackPlugin = require('copy-webpack-plugin'),
WEBPACK_MODE = process.env.npm_lifecycle_event,
HtmlWebpackUrlPlugin = require('html-webpack-url-plugin')
;
const config = {
entry: {
app: path.resolve(__dirname, 'src', 'js', 'index.jsx')
},
output: {
path: path.resolve(__dirname, 'public'),
filename: '[name].[hash].js'
},
devtool: (WEBPACK_MODE === 'build') ? false : 'source-map',
module: {
rules: [
{
test: /\.css$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: ['css-loader?modules=true', 'postcss-loader']
})
},
{
test: /\.js[x]?$/,
exclude: /(node_modules)/,
use: 'babel-loader'
}
]
},
devServer: {
contentBase: path.join(__dirname, "public"),
compress: true,
port: 8888
},
plugins: [
new HtmlWebpackPlugin({
chunks: ['app']
}),
new ExtractTextPlugin('main.css'),
new CopyWebpackPlugin([{
from: path.resolve(__dirname, 'src', 'images'),
to: path.resolve(__dirname, 'public', 'images')
}]),
new HtmlWebpackUrlPlugin({
url: 'http://localhost:8123'
})
]
};
if (WEBPACK_MODE === 'build') {
config.plugins = [...config.plugins, new UglifyJsPlugin()]
}
module.exports = config;