webpack.config.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. const path = require('path')
  2. const webpack = require('webpack')
  3. module.exports = {
  4. target: 'node',
  5. entry: 'src/index.ts',
  6. devtool: 'source-map',
  7. context: __dirname,
  8. mode: 'development',
  9. output: {
  10. path: path.resolve(__dirname, 'dist'),
  11. filename: 'index.js',
  12. pathinfo: true,
  13. libraryTarget: 'umd',
  14. devtoolModuleFilenameTemplate: 'webpack-terminus-settings:///[resource-path]',
  15. },
  16. mode: process.env.TERMINUS_DEV ? 'development' : 'production',
  17. optimization:{
  18. minimize: false,
  19. },
  20. resolve: {
  21. modules: ['.', 'src', 'node_modules', '../app/node_modules'].map(x => path.join(__dirname, x)),
  22. extensions: ['.ts', '.js'],
  23. },
  24. module: {
  25. rules: [
  26. {
  27. test: /\.ts$/,
  28. use: {
  29. loader: 'awesome-typescript-loader',
  30. options: {
  31. configFileName: path.resolve(__dirname, 'tsconfig.json'),
  32. typeRoots: [
  33. path.resolve(__dirname, 'node_modules/@types'),
  34. path.resolve(__dirname, '../node_modules/@types')
  35. ],
  36. paths: {
  37. "terminus-*": [path.resolve(__dirname, '../terminus-*')],
  38. "*": [path.resolve(__dirname, '../app/node_modules/*')],
  39. }
  40. }
  41. }
  42. },
  43. { test: /\.pug$/, use: ['apply-loader', 'pug-loader'] },
  44. { test: /\.scss$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
  45. { test: /\.css$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
  46. { test: /\.svg/, use: ['svg-inline-loader'] },
  47. ]
  48. },
  49. externals: [
  50. 'fs',
  51. 'path',
  52. 'os',
  53. /^rxjs/,
  54. /^@angular/,
  55. /^@ng-bootstrap/,
  56. /^terminus-/,
  57. ],
  58. plugins: [
  59. new webpack.optimize.ModuleConcatenationPlugin(),
  60. ],
  61. }