webpack.config.js 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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, './legacy/legacy.ts'),
  9. },
  10. output: {
  11. path: path.resolve(__dirname, '../dist/preview release/gui'),
  12. filename: 'babylonjs.proceduralTextures.min.js',
  13. libraryTarget: 'umd',
  14. library: {
  15. root: ["PTLIB"],
  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: 'awesome-typescript-loader',
  38. options: {
  39. configFileName: '../../proceduralTexturesLibrary/tsconfig.json',
  40. declarationDir: '../../dist/preview release/proceduralTexturesLibrary/build'
  41. }
  42. },
  43. {
  44. test: /\.fx$/,
  45. use: [{
  46. loader: path.resolve(__dirname, '../Tools/WebpackShaderLoader/index.js')
  47. }]
  48. }]
  49. },
  50. mode: "production",
  51. devServer: {
  52. contentBase: path.join(__dirname, "dist"),
  53. compress: false,
  54. //open: true,
  55. port: 9000
  56. },
  57. plugins: [
  58. new CleanWebpackPlugin([
  59. path.resolve(__dirname, './src/**/*.js'),
  60. path.resolve(__dirname, './src/**/*.map')
  61. ]),
  62. // moved out of here due to the way gulp works...
  63. /*new DtsBundleWebpack({
  64. name: "babylonjs-gui",
  65. main: path.resolve(__dirname, '../dist/preview release/gui/build/index.d.ts'),
  66. out: path.resolve(__dirname, '../dist/preview release/gui/babylon.gui.module.d.ts'),
  67. baseDir: path.resolve(__dirname, '../dist/preview release/gui/build/'),
  68. headerText: "BabylonJS GUI"
  69. }),*/
  70. new webpack.WatchIgnorePlugin([
  71. /\.js$/,
  72. /\.d\.ts$/
  73. ])
  74. ],
  75. watchOptions: {
  76. ignored: [path.resolve(__dirname, './dist/**/*.*'), 'node_modules']
  77. }
  78. }