codimd/webpackBaseConfig.js

168 lines
5.9 KiB
JavaScript
Raw Normal View History

2016-10-11 15:45:00 +08:00
var webpack = require('webpack');
var path = require('path');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
2016-10-13 08:56:56 +08:00
var HtmlWebpackPlugin = require('html-webpack-plugin');
2016-10-11 15:45:00 +08:00
module.exports = {
plugins: [
new webpack.ProvidePlugin({
Visibility: "visibilityjs",
Cookies: "js-cookie",
key: "keymaster",
$: "jquery",
jQuery: "jquery",
2016-10-13 16:25:04 +08:00
"window.jQuery": "jquery",
2016-10-13 16:35:43 +08:00
"moment": "moment",
"Handlebars": "handlebars"
2016-10-11 15:45:00 +08:00
}),
new ExtractTextPlugin("[name].css"),
new webpack.optimize.CommonsChunkPlugin({
names: ["cover", "index", "pretty", "slide", "vendor"],
2016-10-13 08:56:56 +08:00
children: true,
async: true,
filename: '[name].js',
minChunks: Infinity
2016-10-13 08:56:56 +08:00
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['vendor', 'index'],
filename: path.join(__dirname, 'public/views/build/index-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['vendor', 'index'],
filename: path.join(__dirname, 'public/views/build/index-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['vendor', 'cover'],
2016-10-13 08:56:56 +08:00
filename: path.join(__dirname, 'public/views/build/cover-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['vendor', 'cover'],
2016-10-13 08:56:56 +08:00
filename: path.join(__dirname, 'public/views/build/cover-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['vendor', 'pretty'],
2016-10-13 08:56:56 +08:00
filename: path.join(__dirname, 'public/views/build/pretty-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['vendor', 'pretty'],
2016-10-13 08:56:56 +08:00
filename: path.join(__dirname, 'public/views/build/pretty-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['vendor', 'slide'],
filename: path.join(__dirname, 'public/views/build/slide-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['vendor', 'slide'],
filename: path.join(__dirname, 'public/views/build/slide-scripts.ejs'),
inject: false
2016-10-11 15:45:00 +08:00
})
],
entry: {
cover: path.join(__dirname, 'public/js/cover.js'),
2016-10-11 15:45:00 +08:00
index: path.join(__dirname, 'public/js/index.js'),
pretty: path.join(__dirname, 'public/js/pretty.js'),
2016-10-11 15:45:00 +08:00
slide: path.join(__dirname, 'public/js/slide.js'),
vendor: [
2016-10-13 13:59:34 +08:00
"imports?$=jquery!jquery-mousewheel",
2016-10-11 15:45:00 +08:00
"expose?filterXSS!xss",
"js-url",
2016-10-12 17:03:47 +08:00
"expose?Spinner!spin.js",
"script!Idle.Js",
2016-10-13 08:56:56 +08:00
"expose?LZString!lz-string",
"script!codemirror",
"script!select2",
"script!inlineAttachment",
"script!jqueryTextcomplete",
"script!codemirrorSpellChecker",
"script!codemirrorInlineAttachment",
"script!ot",
"flowchart.js",
"js-sequence-diagrams"
2016-10-11 15:45:00 +08:00
]
},
output: {
path: path.join(__dirname, 'public/build'),
publicPath: '/build/',
2016-10-11 15:45:00 +08:00
filename: '[name].js'
},
resolve: {
2016-10-13 08:56:56 +08:00
modulesDirectories: [
2016-10-11 15:45:00 +08:00
path.resolve(__dirname, 'src'),
path.resolve(__dirname, 'node_modules')
],
2016-10-13 08:56:56 +08:00
extensions: ["", ".js"],
alias: {
codemirror: path.join(__dirname, 'public/vendor/codemirror/codemirror.min.js'),
select2: path.join(__dirname, 'public/vendor/select2/select2.min.js'),
inlineAttachment: path.join(__dirname, 'public/vendor/inlineAttachment/inline-attachment.js'),
jqueryTextcomplete: path.join(__dirname, 'public/vendor/jquery-textcomplete/jquery.textcomplete.js'),
codemirrorSpellChecker: path.join(__dirname, 'public/vendor/codemirror-spell-checker/spell-checker.min.js'),
codemirrorInlineAttachment: path.join(__dirname, 'public/vendor/inlineAttachment/codemirror.inline-attachment.js'),
ot: path.join(__dirname, 'public/vendor/ot/ot.min.js')
}
2016-10-11 15:45:00 +08:00
},
2016-10-13 08:56:02 +08:00
externals: {
"viz.js": "Viz",
"socket.io-client": "io",
"lodash": "_",
2016-10-13 15:13:03 +08:00
"jquery": "$",
2016-10-13 16:35:43 +08:00
"moment": "moment",
2016-10-14 09:21:41 +08:00
"handlebars": "Handlebars",
"highlight.js": "hljs"
2016-10-13 08:56:02 +08:00
},
2016-10-11 15:45:00 +08:00
module: {
loaders: [{
test: /\.json$/,
loader: 'json-loader'
}, {
test: /\.css$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader')
}, {
test: /\.scss$/,
loader: ExtractTextPlugin.extract('style-loader', 'sass-loader')
}, {
test: /\.less$/,
loader: ExtractTextPlugin.extract('style-loader', 'less-loader')
}, {
test: require.resolve("js-sequence-diagrams"),
loader: "imports?Raphael=raphael"
}, {
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
loader: "file"
}, {
test: /\.(woff|woff2)$/,
loader: "url?prefix=font/&limit=5000"
}, {
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
loader: "url?limit=10000&mimetype=application/octet-stream"
}, {
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
loader: "url?limit=10000&mimetype=image/svg+xml"
2016-10-14 09:56:19 +08:00
}]
2016-10-11 15:45:00 +08:00
},
node: {
fs: "empty"
}
};