webpack.config.js 2.2 KB

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