webpack.start.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /**
  2. * @fileoverview demo.
  3. *
  4. * @author <a href="http://vanessa.b3log.org">Liyuan Li</a>
  5. * @version 0.2.0.0, Sep 2, 2019
  6. */
  7. const path = require('path')
  8. const webpack = require('webpack')
  9. const HtmlWebpackPlugin = require('html-webpack-plugin')
  10. const CopyPlugin = require('copy-webpack-plugin')
  11. const pkg = require('./package.json')
  12. module.exports = {
  13. mode: 'development',
  14. watch: true,
  15. output: {
  16. filename: '[name]',
  17. path: path.resolve(__dirname, 'demo/dist'),
  18. },
  19. entry: {
  20. 'index.js': './demo/index.js',
  21. },
  22. resolve: {
  23. extensions: ['.js', '.ts', '.svg', '.png', '.scss'],
  24. },
  25. module: {
  26. rules: [
  27. {
  28. test: /\.scss$/,
  29. include: [path.resolve(__dirname, 'src')],
  30. use: [
  31. {
  32. loader: 'style-loader',
  33. },
  34. {
  35. loader: 'css-loader', // translates CSS into CommonJS
  36. options: {
  37. url: false,
  38. },
  39. },
  40. {
  41. loader: 'postcss-loader',
  42. options: {
  43. ident: 'postcss',
  44. plugins: () => [
  45. require('autoprefixer')({grid: true, remove: false}),
  46. ],
  47. },
  48. },
  49. {
  50. loader: 'sass-loader', // compiles Sass to CSS
  51. },
  52. ],
  53. },
  54. {
  55. test: /\.svg$/,
  56. include: [path.resolve(__dirname, './src/assets/icons')],
  57. use: [
  58. {
  59. loader: 'html-loader',
  60. options: {
  61. minimize: true,
  62. },
  63. },
  64. ],
  65. },
  66. {
  67. test: /\.ts$/,
  68. use: 'ts-loader',
  69. },
  70. {
  71. test: /\.js$/,
  72. exclude: '/node_modules/',
  73. use: {
  74. loader: 'babel-loader',
  75. options: {
  76. presets: [
  77. [
  78. '@babel/env',
  79. {
  80. targets: {
  81. browsers: [
  82. 'last 2 Chrome major versions',
  83. 'last 2 Firefox major versions',
  84. 'last 2 Safari major versions',
  85. 'last 2 Edge major versions',
  86. 'last 2 iOS major versions',
  87. 'last 2 ChromeAndroid major versions',
  88. ],
  89. },
  90. },
  91. ],
  92. ],
  93. },
  94. },
  95. },
  96. {
  97. test: /\.png$/,
  98. include: [path.resolve(__dirname, './src/assets/images')],
  99. use: [
  100. 'file-loader',
  101. ],
  102. },
  103. ],
  104. },
  105. plugins: [
  106. new HtmlWebpackPlugin({
  107. chunks: ['index.js'],
  108. filename: './index.html',
  109. template: './demo/index.html',
  110. }),
  111. new webpack.DefinePlugin({
  112. VDITOR_VERSION: JSON.stringify(pkg.version),
  113. CDN_PATH: JSON.stringify(pkg.cdn),
  114. }),
  115. new CopyPlugin([
  116. {from: 'src/images', to: 'images'},
  117. {from: 'src/js', to: 'js'},
  118. ]),
  119. ],
  120. devServer: {
  121. contentBase: path.join(__dirname, '.'),
  122. port: 9000,
  123. host: '0.0.0.0',
  124. before: (app) => {
  125. app.get('/dist/js/lute/lute.wasm.br', function (req, res, next) {
  126. res.set({
  127. 'Content-Encoding': 'br',
  128. 'Content-Type': 'application/wasm',
  129. })
  130. next()
  131. })
  132. },
  133. proxy: {
  134. '/api': {
  135. target: 'http://localhost:8080',
  136. pathRewrite: {'^/api': ''},
  137. },
  138. '/hacpai': {
  139. target: 'https://hacpai.com',
  140. pathRewrite: {'^/hacpai': ''},
  141. },
  142. },
  143. },
  144. }