gulpfile.js 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. var gulp = require('gulp');
  2. var $ = require('gulp-load-plugins')();
  3. var path = require('path');
  4. var del = require('del');
  5. var distPath = path.resolve('./dist');
  6. var version = ''; // 版本号
  7. var versionPath = ''; // 版本号路径
  8. var env = ''; // 运行环境
  9. // 创建版本号(年月日时分)
  10. (function () {
  11. var d = new Date();
  12. var yy = d.getFullYear().toString().slice(2);
  13. var MM = d.getMonth() + 1 >= 10 ? (d.getMonth() + 1) : '0' + (d.getMonth() + 1);
  14. var DD = d.getDate() >= 10 ? d.getDate() : '0' + d.getDate();
  15. var h = d.getHours() >= 10 ? d.getHours() : '0' + d.getHours();
  16. var mm = d.getMinutes() >= 10 ? d.getMinutes() : '0' + d.getMinutes();
  17. version = yy + MM + DD + h + mm;
  18. versionPath = distPath + '/' + version;
  19. })();
  20. // 编译
  21. gulp.task('build', $.shell.task([ 'node build/build.js' ]));
  22. // 创建版本号目录
  23. gulp.task('create:versionCatalog', ['build'], function () {
  24. return gulp.src(`${distPath}/static/**/*`)
  25. .pipe(gulp.dest(`${versionPath}/static/`))
  26. });
  27. // 替换${versionPath}/static/js/manifest.js window.SITE_CONFIG.cdnUrl占位变量
  28. gulp.task('replace:cdnUrl', ['create:versionCatalog'], function () {
  29. return gulp.src(`${versionPath}/static/js/manifest.js`)
  30. .pipe($.replace(new RegExp(`"${require('./config').build.assetsPublicPath}"`, 'g'), 'window.SITE_CONFIG.cdnUrl + "/"'))
  31. .pipe(gulp.dest(`${versionPath}/static/js/`))
  32. });
  33. // 替换${versionPath}/static/config/index-${env}.js window.SITE_CONFIG['version']配置变量
  34. gulp.task('replace:version', ['create:versionCatalog'], function () {
  35. return gulp.src(`${versionPath}/static/config/index-${env}.js`)
  36. .pipe($.replace(/window.SITE_CONFIG\['version'\] = '.*'/g, `window.SITE_CONFIG['version'] = '${version}'`))
  37. .pipe(gulp.dest(`${versionPath}/static/config/`))
  38. });
  39. // 替换${versionPath}/static/config/index-${env}.js window.SITE_CONFIG['systemName']配置变量
  40. gulp.task('replace:systemName', ['replace:version'], function () {
  41. // 可根据需要自定义 systemName
  42. const systemName = process.env.npm_config_systemname || '木之云数字化平台';
  43. // const systemName = process.env.npm_config_systemname || '东齐航空装备数字化平台';
  44. // const systemName = process.env.npm_config_systemname || '昌柘伟业数字化平台';
  45. return gulp.src(`${versionPath}/static/config/index-${env}.js`)
  46. .pipe($.replace(/window\.SITE_CONFIG\['systemName'\] = '.*'/g, `window.SITE_CONFIG['systemName'] = '${systemName}'`))
  47. .pipe(gulp.dest(`${versionPath}/static/config/`));
  48. });
  49. // 合并${versionPath}/static/config/[index-${env}, init].js 至 ${distPath}/config/index.js
  50. gulp.task('concat:config', ['replace:version'], function () {
  51. return gulp.src([`${versionPath}/static/config/index-${env}.js`, `${versionPath}/static/config/init.js`])
  52. .pipe($.concat('index.js'))
  53. .pipe(gulp.dest(`${distPath}/config/`))
  54. });
  55. // 修改合并任务依赖,确保systemName已替换
  56. gulp.task('concat:config', ['replace:systemName'], function () {
  57. return gulp.src([`${versionPath}/static/config/index-${env}.js`, `${versionPath}/static/config/init.js`])
  58. .pipe($.concat('index.js'))
  59. .pipe(gulp.dest(`${distPath}/config/`));
  60. });
  61. // 清空
  62. gulp.task('clean', function () {
  63. return del([versionPath])
  64. });
  65. gulp.task('default', ['clean'], function () {
  66. // 获取环境配置
  67. env = process.env.npm_config_qa ? 'qa' : process.env.npm_config_uat ? 'uat' : 'prod'
  68. // 开始打包编译
  69. gulp.start(['build', 'create:versionCatalog', 'replace:cdnUrl', 'replace:version', 'concat:config'], function () {
  70. // 清除, 编译 / 处理项目中产生的文件
  71. del([`${distPath}/static`, `${versionPath}/static/config`])
  72. })
  73. });