webpack.start.js 3.6 KB

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