webpack.config.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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. output: {
  9. path: path.resolve(__dirname, 'dist'),
  10. filename: 'index.js',
  11. pathinfo: true,
  12. libraryTarget: 'umd',
  13. devtoolModuleFilenameTemplate: 'webpack-terminus-settings:///[resource-path]',
  14. },
  15. resolve: {
  16. modules: ['.', 'src', 'node_modules', '../app/node_modules'].map(x => path.join(__dirname, x)),
  17. extensions: ['.ts', '.js'],
  18. },
  19. module: {
  20. rules: [
  21. {
  22. test: /\.ts$/,
  23. use: {
  24. loader: 'awesome-typescript-loader',
  25. options: {
  26. configFileName: path.resolve(__dirname, 'tsconfig.json'),
  27. typeRoots: [path.resolve(__dirname, 'node_modules/@types')],
  28. paths: {
  29. "terminus-*": [path.resolve(__dirname, '../terminus-*')],
  30. "*": [path.resolve(__dirname, '../app/node_modules/*')],
  31. }
  32. }
  33. }
  34. },
  35. { test: /\.pug$/, use: ['apply-loader', 'pug-loader'] },
  36. { test: /\.scss$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
  37. { test: /\.css$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
  38. { test: /\.svg/, use: ['svg-inline-loader'] },
  39. ]
  40. },
  41. externals: [
  42. 'fs',
  43. 'path',
  44. /^rxjs/,
  45. /^@angular/,
  46. /^@ng-bootstrap/,
  47. /^terminus-/,
  48. ],
  49. plugins: [
  50. new webpack.optimize.ModuleConcatenationPlugin(),
  51. ],
  52. }