webpack.doc.base.conf.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. const path = require('path');
  2. const webpackBaseConf = require('./webpack.base.conf.js');
  3. const HtmlWebpackPlugin = require('html-webpack-plugin');
  4. const MiniCssExtractPlugin = require("mini-css-extract-plugin");
  5. const merge = require('webpack-merge');
  6. const mdtohtml = require('../scripts/mdToVue');
  7. const isDev = process.env.NODE_ENV === 'development';
  8. module.exports = merge(webpackBaseConf, {
  9. entry: {
  10. app: './sites/doc/app.js',
  11. },
  12. output: {
  13. publicPath: '/',
  14. path: path.resolve(__dirname, '../dist/sites/'),
  15. chunkFilename: 'doc/js/[name].[hash:5].js',
  16. filename: isDev ? 'doc/js/[name].js' : 'doc/js/[name].[hash].js'
  17. },
  18. module: {
  19. rules: [
  20. ]
  21. },
  22. plugins: [
  23. new mdtohtml({
  24. entry:'./src',
  25. output:'./sites/doc/view/',
  26. template:'./doc-site/template.html',
  27. nav:'left',
  28. needCode:true
  29. }),
  30. new mdtohtml({
  31. entry:'./docs',
  32. output:'./sites/doc/page/',
  33. template:'./doc-site/template.html',
  34. nav:'left',
  35. needCode:false
  36. }),
  37. new HtmlWebpackPlugin({
  38. template: './sites/doc/index.html',
  39. filename: 'default.html'
  40. }),
  41. new MiniCssExtractPlugin({
  42. filename: isDev ? 'doc/css/[name].css' : 'doc/css/[name].[hash].css'
  43. })
  44. ]
  45. });