webpack.config.js 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. const path = require('path');
  2. const webpack = require('webpack');
  3. module.exports = {
  4. entry: {
  5. 'viewer': './src/index.ts'
  6. },
  7. output: {
  8. path: path.resolve(__dirname, 'dist'),
  9. filename: '[name].js',
  10. libraryTarget: 'umd',
  11. library: 'BabylonViewer',
  12. umdNamedDefine: true,
  13. devtoolModuleFilenameTemplate: '[relative-resource-path]'
  14. },
  15. resolve: {
  16. extensions: ['.ts', '.js'],
  17. alias: {
  18. "babylonjs": __dirname + '/../dist/preview release/babylon.max.js',
  19. "babylonjs-materials": __dirname + '/../dist/preview release/materialsLibrary/babylonjs.materials.js',
  20. "babylonjs-loaders": __dirname + '/../dist/preview release/loaders/babylonjs.loaders.js',
  21. "pep": __dirname + '/assets/pep.min.js'
  22. }
  23. },
  24. externals: {
  25. // until physics will be integrated in the viewer, ignore cannon
  26. cannon: 'CANNON',
  27. oimo: 'OIMO',
  28. './Oimo': 'OIMO',
  29. "earcut": true
  30. },
  31. devtool: 'source-map',
  32. plugins: [
  33. new webpack.WatchIgnorePlugin([
  34. /\.d\.ts$/
  35. ])
  36. ],
  37. module: {
  38. loaders: [{
  39. test: /\.tsx?$/,
  40. loader: 'ts-loader',
  41. exclude: /node_modules/
  42. },
  43. {
  44. test: /\.(html)$/,
  45. use: {
  46. loader: 'html-loader',
  47. options: {
  48. minimize: true
  49. }
  50. }
  51. },
  52. {
  53. test: /\.(jpe?g|png|ttf|eot|svg?)(\?[a-z0-9=&.]+)?$/,
  54. use: 'base64-image-loader?limit=1000&name=[name].[ext]'
  55. },
  56. {
  57. test: /\.(woff|ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
  58. loader: 'base64-font-loader'
  59. }]
  60. },
  61. devServer: {
  62. contentBase: path.join(__dirname, "dist"),
  63. compress: false,
  64. //open: true,
  65. port: 9000
  66. }
  67. }