gulpTasks-watch.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // Import Dependencies.
  2. var gulp = require("gulp");
  3. var webpack = require('webpack');
  4. var webpackStream = require("webpack-stream");
  5. var debug = require("gulp-debug");
  6. // Read the full config.
  7. var config = require("../config.json");
  8. /**
  9. * Watch ts files from typescript .
  10. * Hack into the cli :-)
  11. */
  12. gulp.task("srcTscWatch", function() {
  13. // Reuse The TSC CLI from gulp to enable -w.
  14. process.argv[2] = "-w";
  15. process.argv[3] = "-p";
  16. process.argv[4] = "../../src/tsconfig.json";
  17. require("../../../node_modules/typescript/lib/tsc.js");
  18. return Promise.resolve();
  19. });
  20. /**
  21. * Watch ts files and fire repective tasks.
  22. */
  23. gulp.task("watch", gulp.series("srcTscWatch", function startWatch() {
  24. var tasks = [];
  25. config.modules.map(function(module) {
  26. if (config[module].build && config[module].build.webpack) {
  27. var library = config[module].libraries[0];
  28. if (library.noWatch) return;
  29. var outputDirectory = config.build.tempDirectory + config[module].build.distOutputDirectory;
  30. let wpconfig = require("../" + config[module].build.webpack);
  31. wpconfig.watch = true;
  32. // dev mode and absolute path sourcemaps for debugging
  33. wpconfig.mode = "development";
  34. wpconfig.output.devtoolModuleFilenameTemplate = "[absolute-resource-path]";
  35. //config.stats = "minimal";
  36. tasks.push(webpackStream(wpconfig, webpack).pipe(gulp.dest(outputDirectory)))
  37. }
  38. });
  39. console.log(tasks.length);
  40. return Promise.resolve();
  41. }));