webpack.config.js 1.8 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-core:///[resource-path]',
  15. },
  16. mode: process.env.DEV ? 'development' : 'production',
  17. resolve: {
  18. modules: ['.', 'src', 'node_modules', '../app/node_modules'].map(x => path.join(__dirname, x)),
  19. extensions: ['.ts', '.js'],
  20. },
  21. module: {
  22. rules: [
  23. {
  24. test: /\.ts$/,
  25. use: {
  26. loader: 'awesome-typescript-loader',
  27. options: {
  28. configFileName: path.resolve(__dirname, 'tsconfig.json'),
  29. typeRoots: [path.resolve(__dirname, 'node_modules/@types')],
  30. paths: {
  31. "terminus-*": [path.resolve(__dirname, '../terminus-*')],
  32. "*": [path.resolve(__dirname, '../app/node_modules/*')],
  33. }
  34. }
  35. }
  36. },
  37. { test: /\.pug$/, use: ['apply-loader', 'pug-loader'] },
  38. { test: /\.scss$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
  39. { test: /\.css$/, use: ['to-string-loader', 'css-loader'], include: /component\.css/ },
  40. { test: /\.css$/, use: ['style-loader', 'css-loader'], exclude: /component\.css/ },
  41. { test: /\.yaml$/, use: ['json-loader', 'yaml-loader'] },
  42. { test: /\.svg/, use: ['svg-inline-loader'] },
  43. ]
  44. },
  45. externals: [
  46. 'electron',
  47. 'fs',
  48. 'os',
  49. 'path',
  50. 'deepmerge',
  51. 'untildify',
  52. 'winston',
  53. 'js-yaml',
  54. /^rxjs/,
  55. /^@angular/,
  56. /^@ng-bootstrap/,
  57. ],
  58. plugins: [
  59. new webpack.optimize.ModuleConcatenationPlugin(),
  60. ],
  61. }