webpack.doc.base.conf.js 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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. isbuild:isDev
  30. }),
  31. new mdtohtml({
  32. entry:'./docs',
  33. output:'./sites/doc/page/',
  34. template:'./doc-site/template.html',
  35. nav:'left',
  36. needCode:false,
  37. isbuild:isDev
  38. }),
  39. new HtmlWebpackPlugin({
  40. template: './sites/doc/index.html',
  41. filename: 'default.html'
  42. }),
  43. new MiniCssExtractPlugin({
  44. filename: isDev ? 'doc/css/[name].css' : 'doc/css/[name].[hash].css'
  45. })
  46. ]
  47. });