webpack.config.js 1.7 KB

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