HackMD/webpackBaseConfig.js

440 lines
18 KiB
JavaScript
Raw Normal View History

2016-10-11 07:45:00 +00:00
var webpack = require('webpack');
var path = require('path');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
2016-10-13 00:56:56 +00:00
var HtmlWebpackPlugin = require('html-webpack-plugin');
var CopyWebpackPlugin = require('copy-webpack-plugin');
2016-10-11 07:45:00 +00:00
module.exports = {
plugins: [
new webpack.ProvidePlugin({
Visibility: "visibilityjs",
Cookies: "js-cookie",
key: "keymaster",
$: "jquery",
jQuery: "jquery",
2016-10-13 08:25:04 +00:00
"window.jQuery": "jquery",
2016-10-13 08:35:43 +00:00
"moment": "moment",
"Handlebars": "handlebars"
2016-10-11 07:45:00 +00:00
}),
new webpack.optimize.OccurrenceOrderPlugin(true),
2016-10-11 07:45:00 +00:00
new webpack.optimize.CommonsChunkPlugin({
names: ["cover", "index", "pretty", "slide", "vendor"],
2016-10-13 00:56:56 +00:00
children: true,
async: true,
filename: '[name].js',
minChunks: Infinity
2016-10-13 00:56:56 +00:00
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font', 'index-styles', 'index'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/index-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font-pack', 'index-styles-pack', 'index-styles', 'index'],
filename: path.join(__dirname, 'public/views/build/index-pack-header.ejs'),
inject: false
}),
2016-10-13 00:56:56 +00:00
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['index'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/index-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['common', 'index-pack'],
filename: path.join(__dirname, 'public/views/build/index-pack-scripts.ejs'),
inject: false
}),
2016-10-13 00:56:56 +00:00
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font', 'cover'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/cover-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font-pack', 'cover-styles-pack', 'cover'],
filename: path.join(__dirname, 'public/views/build/cover-pack-header.ejs'),
inject: false
}),
2016-10-13 00:56:56 +00:00
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['cover'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/cover-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['common', 'cover-pack'],
filename: path.join(__dirname, 'public/views/build/cover-pack-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
2016-10-13 00:56:56 +00:00
template: 'public/views/includes/header.ejs',
chunks: ['font', 'pretty-styles', 'pretty'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/pretty-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font-pack', 'pretty-styles-pack', 'pretty-styles', 'pretty'],
filename: path.join(__dirname, 'public/views/build/pretty-pack-header.ejs'),
inject: false
}),
2016-10-13 00:56:56 +00:00
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['pretty'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/pretty-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['common', 'pretty-pack'],
filename: path.join(__dirname, 'public/views/build/pretty-pack-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
2016-10-13 00:56:56 +00:00
template: 'public/views/includes/header.ejs',
chunks: ['font', 'slide-styles', 'slide'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/slide-header.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/header.ejs',
chunks: ['font-pack', 'slide-styles-pack', 'slide-styles', 'slide'],
filename: path.join(__dirname, 'public/views/build/slide-pack-header.ejs'),
inject: false
}),
2016-10-13 00:56:56 +00:00
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['slide'],
2016-10-13 00:56:56 +00:00
filename: path.join(__dirname, 'public/views/build/slide-scripts.ejs'),
inject: false
}),
new HtmlWebpackPlugin({
template: 'public/views/includes/scripts.ejs',
chunks: ['slide-pack'],
filename: path.join(__dirname, 'public/views/build/slide-pack-scripts.ejs'),
inject: false
}),
new CopyWebpackPlugin([
2017-02-19 07:43:40 +00:00
{
context: path.join(__dirname, 'node_modules/mathjax'),
from: 'MathJax.js',
to: 'MathJax/'
},
{
context: path.join(__dirname, 'node_modules/mathjax'),
from: {
2017-02-19 07:43:40 +00:00
glob: 'config/**/*.js',
dot: false
},
to: 'MathJax/'
},
{
context: path.join(__dirname, 'node_modules/emojify.js'),
from: {
2017-02-19 07:43:40 +00:00
glob: 'dist/**/*',
dot: false
},
to: 'emojify.js/'
},
{
context: path.join(__dirname, 'node_modules/reveal.js'),
2017-02-19 07:43:40 +00:00
from: 'js',
to: 'reveal.js/'
},
{
context: path.join(__dirname, 'node_modules/reveal.js'),
from: 'css',
to: 'reveal.js/'
},
2017-02-19 07:43:40 +00:00
{
context: path.join(__dirname, 'node_modules/reveal.js'),
from: 'lib',
to: 'reveal.js/'
},
{
context: path.join(__dirname, 'node_modules/reveal.js'),
from: 'plugin',
to: 'reveal.js/'
}
])
2016-10-11 07:45:00 +00:00
],
entry: {
font: path.join(__dirname, 'public/css/google-font.css'),
"font-pack": path.join(__dirname, 'public/css/font.css'),
common: [
"expose-loader?jQuery!expose-loader?$!jquery",
"velocity-animate",
"imports-loader?$=jquery!jquery-mousewheel",
"bootstrap"
],
cover: [
"babel-polyfill",
path.join(__dirname, 'public/js/cover.js')
],
"cover-styles-pack": [
path.join(__dirname, 'node_modules/bootstrap/dist/css/bootstrap.min.css'),
path.join(__dirname, 'node_modules/font-awesome/css/font-awesome.min.css'),
path.join(__dirname, 'public/css/bootstrap-social.css'),
path.join(__dirname, 'node_modules/select2/select2.css'),
path.join(__dirname, 'node_modules/select2/select2-bootstrap.css'),
],
"cover-pack": [
"babel-polyfill",
"bootstrap-validator",
"script-loader!listPagnation",
"expose-loader?select2!select2",
"expose-loader?moment!moment",
"script-loader!js-url",
path.join(__dirname, 'public/js/cover.js')
],
index: [
"babel-polyfill",
"script-loader!jquery-ui-resizable",
"script-loader!js-url",
"expose-loader?filterXSS!xss",
"script-loader!Idle.Js",
"expose-loader?LZString!lz-string",
"script-loader!codemirror",
"script-loader!inlineAttachment",
"script-loader!jqueryTextcomplete",
"script-loader!codemirrorSpellChecker",
"script-loader!codemirrorInlineAttachment",
"script-loader!ot",
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/google-drive-upload.js'),
path.join(__dirname, 'public/js/google-drive-picker.js'),
path.join(__dirname, 'public/js/index.js')
],
"index-styles": [
path.join(__dirname, 'public/vendor/jquery-ui/jquery-ui.min.css'),
path.join(__dirname, 'public/vendor/codemirror-spell-checker/spell-checker.min.css'),
path.join(__dirname, 'node_modules/codemirror/lib/codemirror.css'),
path.join(__dirname, 'node_modules/codemirror/addon/fold/foldgutter.css'),
path.join(__dirname, 'node_modules/codemirror/addon/display/fullscreen.css'),
path.join(__dirname, 'node_modules/codemirror/addon/dialog/dialog.css'),
path.join(__dirname, 'node_modules/codemirror/addon/scroll/simplescrollbars.css'),
path.join(__dirname, 'node_modules/codemirror/addon/search/matchesonscrollbar.css'),
path.join(__dirname, 'node_modules/codemirror/theme/monokai.css'),
path.join(__dirname, 'node_modules/codemirror/theme/one-dark.css'),
path.join(__dirname, 'node_modules/codemirror/mode/tiddlywiki/tiddlywiki.css'),
path.join(__dirname, 'node_modules/codemirror/mode/mediawiki/mediawiki.css'),
path.join(__dirname, 'public/css/github-extract.css'),
path.join(__dirname, 'public/vendor/showup/showup.css'),
path.join(__dirname, 'public/css/mermaid.css'),
path.join(__dirname, 'public/css/markdown.css'),
path.join(__dirname, 'public/css/slide-preview.css')
],
"index-styles-pack": [
path.join(__dirname, 'node_modules/bootstrap/dist/css/bootstrap.min.css'),
path.join(__dirname, 'node_modules/font-awesome/css/font-awesome.min.css'),
path.join(__dirname, 'public/css/bootstrap-social.css'),
path.join(__dirname, 'node_modules/ionicons/css/ionicons.min.css'),
path.join(__dirname, 'node_modules/octicons/octicons/octicons.css')
],
"index-pack": [
"babel-polyfill",
"expose-loader?Spinner!spin.js",
"script-loader!jquery-ui-resizable",
"bootstrap-validator",
"expose-loader?jsyaml!js-yaml",
"script-loader!mermaid",
"expose-loader?moment!moment",
"script-loader!js-url",
"script-loader!handlebars",
"expose-loader?hljs!highlight.js",
"expose-loader?emojify!emojify.js",
"expose-loader?filterXSS!xss",
"script-loader!Idle.Js",
"script-loader!gist-embed",
"expose-loader?LZString!lz-string",
"script-loader!codemirror",
"script-loader!inlineAttachment",
"script-loader!jqueryTextcomplete",
"script-loader!codemirrorSpellChecker",
"script-loader!codemirrorInlineAttachment",
"script-loader!ot",
2016-10-13 00:56:56 +00:00
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?Viz!viz.js",
"expose-loader?io!socket.io-client",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/google-drive-upload.js'),
path.join(__dirname, 'public/js/google-drive-picker.js'),
path.join(__dirname, 'public/js/index.js')
],
pretty: [
"babel-polyfill",
"expose-loader?filterXSS!xss",
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/pretty.js')
],
"pretty-styles": [
path.join(__dirname, 'public/css/github-extract.css'),
path.join(__dirname, 'public/css/mermaid.css'),
path.join(__dirname, 'public/css/markdown.css'),
path.join(__dirname, 'public/css/slide-preview.css')
],
"pretty-styles-pack": [
path.join(__dirname, 'node_modules/bootstrap/dist/css/bootstrap.min.css'),
path.join(__dirname, 'node_modules/font-awesome/css/font-awesome.min.css'),
path.join(__dirname, 'node_modules/ionicons/css/ionicons.min.css'),
path.join(__dirname, 'node_modules/octicons/octicons/octicons.css')
],
"pretty-pack": [
"babel-polyfill",
"expose-loader?jsyaml!js-yaml",
"script-loader!mermaid",
"expose-loader?moment!moment",
"script-loader!handlebars",
"expose-loader?hljs!highlight.js",
"expose-loader?emojify!emojify.js",
"expose-loader?filterXSS!xss",
"script-loader!gist-embed",
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?Viz!viz.js",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/pretty.js')
],
slide: [
"babel-polyfill",
"bootstrap-tooltip",
"expose-loader?filterXSS!xss",
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/slide.js')
],
"slide-styles": [
path.join(__dirname, 'public/vendor/bootstrap/tooltip.min.css'),
path.join(__dirname, 'public/css/github-extract.css'),
path.join(__dirname, 'public/css/mermaid.css'),
path.join(__dirname, 'public/css/markdown.css')
],
"slide-styles-pack": [
path.join(__dirname, 'node_modules/font-awesome/css/font-awesome.min.css'),
path.join(__dirname, 'node_modules/ionicons/css/ionicons.min.css'),
path.join(__dirname, 'node_modules/octicons/octicons/octicons.css')
],
"slide-pack": [
"babel-polyfill",
"expose-loader?jQuery!expose-loader?$!jquery",
"velocity-animate",
"imports-loader?$=jquery!jquery-mousewheel",
"bootstrap-tooltip",
"expose-loader?jsyaml!js-yaml",
"script-loader!mermaid",
"expose-loader?moment!moment",
"script-loader!handlebars",
"expose-loader?hljs!highlight.js",
"expose-loader?emojify!emojify.js",
"expose-loader?filterXSS!xss",
"script-loader!gist-embed",
"flowchart.js",
"js-sequence-diagrams",
"expose-loader?Viz!viz.js",
"headjs",
"expose-loader?Reveal!reveal.js",
"expose-loader?RevealMarkdown!reveal-markdown",
path.join(__dirname, 'public/js/slide.js')
2016-10-11 07:45:00 +00:00
]
},
output: {
path: path.join(__dirname, 'public/build'),
publicPath: '/build/',
filename: '[name].js'
2016-10-11 07:45:00 +00:00
},
resolve: {
modules: [
2016-10-11 07:45:00 +00:00
path.resolve(__dirname, 'src'),
path.resolve(__dirname, 'node_modules')
],
extensions: [".js"],
2016-10-13 00:56:56 +00:00
alias: {
codemirror: path.join(__dirname, 'node_modules/codemirror/codemirror.min.js'),
2016-10-13 00:56:56 +00:00
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'),
listPagnation: path.join(__dirname, 'node_modules/list.pagination.js/dist/list.pagination.min.js'),
mermaid: path.join(__dirname, 'node_modules/mermaid/dist/mermaid.min.js'),
handlebars: path.join(__dirname, 'node_modules/handlebars/dist/handlebars.min.js'),
"jquery-ui-resizable": path.join(__dirname, 'public/vendor/jquery-ui/jquery-ui.min.js'),
"gist-embed": path.join(__dirname, 'node_modules/gist-embed/gist-embed.min.js'),
"bootstrap-tooltip": path.join(__dirname, 'public/vendor/bootstrap/tooltip.min.js'),
"headjs": path.join(__dirname, 'node_modules/reveal.js/lib/js/head.min.js'),
2016-11-28 10:33:53 +00:00
"reveal-markdown": path.join(__dirname, 'public/js/reveal-markdown.js')
2016-10-13 00:56:56 +00:00
}
2016-10-11 07:45:00 +00:00
},
2016-10-13 00:56:02 +00:00
externals: {
"viz.js": "Viz",
"socket.io-client": "io",
"lodash": "_",
2016-10-13 07:13:03 +00:00
"jquery": "$",
2016-10-13 08:35:43 +00:00
"moment": "moment",
2016-10-14 01:21:41 +00:00
"handlebars": "Handlebars",
"highlight.js": "hljs",
"select2": "select2"
2016-10-13 00:56:02 +00:00
},
2016-10-11 07:45:00 +00:00
module: {
rules: [{
2016-10-11 07:45:00 +00:00
test: /\.json$/,
loader: 'json-loader'
2016-12-24 03:10:18 +00:00
}, {
test: /\.js$/,
loader: 'babel-loader',
2016-12-24 03:10:18 +00:00
exclude: [/node_modules/, /public\/vendor/]
2016-10-11 07:45:00 +00:00
}, {
test: /\.css$/,
loader: ExtractTextPlugin.extract({ fallback: 'style-loader', use: 'css-loader' })
2016-10-11 07:45:00 +00:00
}, {
test: /\.scss$/,
loader: ExtractTextPlugin.extract({ fallback: 'style-loader', use: 'sass-loader' })
2016-10-11 07:45:00 +00:00
}, {
test: /\.less$/,
loader: ExtractTextPlugin.extract({ fallback: 'style-loader', use: 'less-loader' })
2016-10-11 07:45:00 +00:00
}, {
test: require.resolve("js-sequence-diagrams"),
loader: "imports-loader?Raphael=raphael"
2016-10-11 07:45:00 +00:00
}, {
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
loader: "file-loader"
2016-10-11 07:45:00 +00:00
}, {
test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/,
loader: "url-loader?prefix=font/&limit=5000"
2016-10-11 07:45:00 +00:00
}, {
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
loader: "url-loader?limit=10000&mimetype=application/octet-stream"
2016-10-11 07:45:00 +00:00
}, {
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
loader: "url-loader?limit=10000&mimetype=image/svg+xml"
}, {
test: /\.png(\?v=\d+\.\d+\.\d+)?$/,
loader: "url-loader?limit=10000&mimetype=image/png"
}, {
test: /\.gif(\?v=\d+\.\d+\.\d+)?$/,
loader: "url-loader?limit=10000&mimetype=image/gif"
2016-10-14 01:56:19 +00:00
}]
2016-10-11 07:45:00 +00:00
},
node: {
fs: "empty"
}
};