webpack.config.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. const path = require('path');
  2. const webpack = require('webpack');
  3. const DtsBundleWebpack = require('dts-bundle-webpack');
  4. const CleanWebpackPlugin = require('clean-webpack-plugin');
  5. module.exports = {
  6. context: __dirname,
  7. entry: {
  8. 'babylonjs-procedural-textures': path.resolve(__dirname, './src/legacy.ts'),
  9. },
  10. output: {
  11. path: path.resolve(__dirname, '../dist/preview release/gui'),
  12. filename: 'babylon.proceduralTextures.min.js',
  13. libraryTarget: 'umd',
  14. library: {
  15. root: ["PROCEDURALTEXTURESLIB"],
  16. amd: "babylonjs-procedural-textures",
  17. commonjs: "babylonjs-procedural-textures"
  18. },
  19. umdNamedDefine: true,
  20. //devtoolModuleFilenameTemplate: "[absolute-resource-path]"
  21. },
  22. resolve: {
  23. extensions: [".js", '.ts']
  24. },
  25. externals: {
  26. babylonjs: {
  27. root: "BABYLON",
  28. commonjs: "babylonjs",
  29. commonjs2: "babylonjs",
  30. amd: "babylonjs"
  31. }
  32. },
  33. devtool: "source-map",
  34. module: {
  35. rules: [{
  36. test: /\.tsx?$/,
  37. loader: "ts-loader",
  38. exclude: /node_modules/
  39. },
  40. {
  41. test: /\.fx$/,
  42. use: [{
  43. loader: path.resolve(__dirname, '../Tools/WebpackShaderLoader/index.js')
  44. }]
  45. }]
  46. },
  47. mode: "production",
  48. devServer: {
  49. contentBase: path.join(__dirname, "dist"),
  50. compress: false,
  51. //open: true,
  52. port: 9000
  53. },
  54. plugins: [
  55. new CleanWebpackPlugin([
  56. path.resolve(__dirname, './src/**/*.js'),
  57. path.resolve(__dirname, './src/**/*.map')
  58. ]),
  59. // moved out of here due to the way gulp works...
  60. /*new DtsBundleWebpack({
  61. name: "babylonjs-gui",
  62. main: path.resolve(__dirname, '../dist/preview release/gui/build/index.d.ts'),
  63. out: path.resolve(__dirname, '../dist/preview release/gui/babylon.gui.module.d.ts'),
  64. baseDir: path.resolve(__dirname, '../dist/preview release/gui/build/'),
  65. headerText: "BabylonJS GUI"
  66. }),*/
  67. new webpack.WatchIgnorePlugin([
  68. /\.js$/,
  69. /\.d\.ts$/
  70. ])
  71. ],
  72. watchOptions: {
  73. ignored: [path.resolve(__dirname, './dist/**/*.*'), 'node_modules']
  74. }
  75. }