webpack.config.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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-gui': path.resolve(__dirname, './src/index.ts'),
  9. },
  10. output: {
  11. path: path.resolve(__dirname, '../dist/preview release/gui'),
  12. filename: 'babylon.gui.js',
  13. libraryTarget: 'umd',
  14. library: {
  15. root: ["BABYLON", "GUI"],
  16. amd: "babylonjs-gui",
  17. commonjs: "babylonjs-gui"
  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. new DtsBundleWebpack({
  60. name: "babylonjs-gui",
  61. main: path.resolve(__dirname, '../dist/preview release/gui/build/index.d.ts'),
  62. out: path.resolve(__dirname, '../dist/preview release/gui/babylon.gui.module.d.ts'),
  63. baseDir: path.resolve(__dirname, '../dist/preview release/gui/build/'),
  64. headerText: "BabylonJS GUI"
  65. }),
  66. new webpack.WatchIgnorePlugin([
  67. /\.js$/,
  68. /\.d\.ts$/
  69. ])
  70. ],
  71. watchOptions: {
  72. ignored: [path.resolve(__dirname, './dist/**/*.*'), 'node_modules']
  73. }
  74. }