gulpfile.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. /**
  2. * Created by chen on 2017/9/26.
  3. */
  4. let gulp =require( 'gulp');
  5. let gulpLoadPlugins = require('gulp-load-plugins');
  6. let del = require('del');
  7. let uglify = require('gulp-uglify-es').default;
  8. let config = require("./config/gulpConfig.js");
  9. const $ = gulpLoadPlugins();
  10. let common_jspaths=config.common_jspaths;
  11. let common_css=config.common_css;
  12. let pm_jspaths=config.pm_jspaths;
  13. let pm_csspaths=config.pm_css;
  14. let login_jspaths=config.login_jspaths;
  15. let main_jspaths=config.main_jspaths;
  16. let main_csspaths=config.main_css;
  17. let compleGlj_jspaths = config.compleGlj_jspaths;
  18. let compleGlj_csspaths = config.compleGlj_css;
  19. let compleRation_ration_jspaths = config.compleRation_ration_jspaths;
  20. let compleRation_ration_csspaths = config.compleRation_ration_css;
  21. let compleRation_glj_jspaths = config.compleRation_glj_jspaths;
  22. let compleRation_glj_csspaths = config.compleRation_glj_css;
  23. let compleRation_coe_jspaths = config.compleRation_coe_jspaths;
  24. let compleRation_coe_csspaths = config.compleRation_coe_css;
  25. let compleRation_inst_csspaths = config.compleRation_inst_css;
  26. let compleRation_inst_jspaths = config.compleRation_inst_jspaths;
  27. let version=config.version;
  28. let cssDest='web/dest/css';
  29. let scriptsDest='web/dest/scripts';
  30. let commonOptions={
  31. jspaths:common_jspaths,
  32. csspaths:common_css,
  33. concatName:'common.all.min'
  34. };
  35. let headerOptions={
  36. version:version,
  37. scriptsDest:'web/dest/scripts',
  38. concatName:'header.all.min',
  39. srcHtml:'web/src/html/common/header.html',
  40. htmlDest:'web/common/html',
  41. htmlName:'header.html',
  42. injectList:['web/dest/scripts/common.all.min.'+version+'.js']
  43. };
  44. let loginOptions={
  45. version:version,
  46. scriptsDest:'web/dest/scripts',
  47. jspaths:login_jspaths,
  48. concatName:'login.all.min',
  49. srcHtml:'web/src/html/login/login.html',
  50. htmlDest:'web/users/html',
  51. htmlName:'login.html',
  52. injectList:[ 'web/dest/scripts/common.all.min.'+version+'.js',
  53. 'web/dest/scripts/login.all.min.'+version+'.js',
  54. 'web/dest/css/common.all.min.'+version+'.css']
  55. }
  56. let pmOptions={
  57. version:version,
  58. scriptsDest:'web/dest/scripts',
  59. jspaths:pm_jspaths,
  60. csspaths:pm_csspaths,
  61. concatName:'pm.all.min',
  62. srcHtml:'web/src/html/pm/!*.html',
  63. htmlDest:'web/building_saas/pm/html',
  64. htmlName:'project-management.html',
  65. injectList:['web/dest/scripts/pm.all.min.'+version+'.js',
  66. 'web/dest/css/common.all.min.'+version+'.css',
  67. 'web/dest/css/pm.all.min.'+version+'.css']
  68. };
  69. let mainOptions={
  70. version:version,
  71. scriptsDest:'web/dest/scripts',
  72. jspaths:main_jspaths,
  73. csspaths:main_csspaths,
  74. concatName:'main.all.min',
  75. srcHtml:'web/src/html/main/main.html',
  76. htmlDest:'web/building_saas/main/html',
  77. htmlName:'main.html',
  78. injectList:['web/dest/scripts/main.all.min.'+version+'.js',
  79. 'web/dest/css/common.all.min.'+version+'.css',
  80. 'web/dest/css/main.all.min.'+version+'.css']
  81. }
  82. let compleGljOptions = {
  83. version: version,
  84. scriptsDest: 'web/dest/scripts',
  85. jspaths: compleGlj_jspaths,
  86. csspaths: compleGlj_csspaths,
  87. concatName: 'compleGlj.all.min',
  88. srcHtml: 'web/src/html/complementary_glj_lib/tools-gongliaoji.html',
  89. htmlDest: 'web/building_saas/complementary_glj_lib/html/tools-gongliaoji.html',
  90. htmlName: 'tools-gongliaoji.html',
  91. injectList: [
  92. 'web/dest/scripts/compleGlj.all.min' + version + '.js',
  93. 'web/dest/css/compleGlj.all.min' + version + '.css',
  94. 'web/dest/css/common.all.min.' + version + '.css'
  95. ]
  96. };
  97. let compleRation_rationOptions = {
  98. version: version,
  99. scriptsDest: 'web/dest/scripts',
  100. jspaths: compleRation_ration_jspaths,
  101. csspaths: compleRation_ration_csspaths,
  102. concatName: 'compleRation_ration.all.min',
  103. srcHtml: 'web/src/html/complementary_ration_lib/dinge.html',
  104. htmlDest: 'web/building_saas/complementary_ration_lib/html/dinge.html',
  105. htmlName: 'dinge.html',
  106. injectList: [
  107. 'web/dest/scripts/compleRation_ration.all.min' + version + '.js',
  108. 'web/dest/css/compleRation_ration.all.min' + version + '.css',
  109. 'web/dest/scripts/common.all.min.'+version+'.js',
  110. 'web/dest/css/common.all.min.' + version + '.css'
  111. ]
  112. };
  113. let compleRation_gljOptions = {
  114. version: version,
  115. scriptsDest: 'web/dest/scripts',
  116. jspaths: compleRation_glj_jspaths,
  117. csspaths: compleRation_glj_csspaths,
  118. concatName: 'compleRation_glj.all.min',
  119. srcHtml: 'web/src/html/complementary_ration_lib/gongliao.html',
  120. htmlDest: 'web/building_saas/complementary_ration_lib/html/gongliao.html',
  121. htmlName: 'gongliao.html',
  122. injectList: [
  123. 'web/dest/scripts/compleRation_glj.all.min' + version + '.js',
  124. 'web/dest/scripts/compleRation_glj.all.min' + version + '.css',
  125. 'web/dest/scripts/common.all.min.'+version+'.js',
  126. 'web/dest/css/common.all.min.' + version + '.css'
  127. ]
  128. };
  129. let compleRation_coeOptions = {
  130. version: version,
  131. scriptsDest: 'web/dest/scripts',
  132. jspaths: compleRation_coe_jspaths,
  133. csspaths: compleRation_coe_csspaths,
  134. concatName: 'compleRation_coe.all.min',
  135. srcHtml: 'web/src/html/complementary_ration_lib/fuzhu.html',
  136. htmlDest: 'web/building_saas/complementary_ration_lib/html/fuzhu.html',
  137. htmlName: 'fuzhu.html',
  138. injectList: [
  139. 'web/dest/scripts/compleRation_coe.all.min' + version + '.js',
  140. 'web/dest/scripts/compleRation_coe.all.min' + version + '.css',
  141. 'web/dest/scripts/common.all.min.'+version+'.js',
  142. 'web/dest/css/common.all.min.' + version + '.css'
  143. ]
  144. };
  145. let compleRation_instOptions = {
  146. version: version,
  147. scriptsDest: 'web/dest/scripts',
  148. jspaths: compleRation_inst_jspaths,
  149. csspaths: compleRation_inst_csspaths,
  150. concatName: 'compleRation_inst.all.min',
  151. srcHtml: 'web/src/html/complementary_ration_lib/anzhuang.html',
  152. htmlDest: 'web/building_saas/complementary_ration_lib/html/anzhuang.html',
  153. htmlName: 'anzhuang.html',
  154. injectList: [
  155. 'web/dest/scripts/compleRation_inst.all.min' + version + '.js',
  156. 'web/dest/scripts/compleRation_inst.all.min' + version + '.css',
  157. 'web/dest/scripts/common.all.min.'+version+'.js',
  158. 'web/dest/css/common.all.min.' + version + '.css'
  159. ]
  160. }
  161. function minify(options) {
  162. if(options.jspaths){
  163. return gulp.src(options.jspaths)
  164. .pipe($.plumber())
  165. .pipe(uglify())
  166. .pipe($.concat(options.concatName+"."+version+".js"))
  167. .pipe(gulp.dest(scriptsDest));
  168. }
  169. return;
  170. }
  171. function css(options) {
  172. if(options.csspaths){
  173. return gulp.src(options.csspaths)
  174. .pipe($.plumber())
  175. .pipe($.cssnano())
  176. .pipe($.concat(options.concatName+"."+version+".css"))
  177. .pipe(gulp.dest(cssDest));
  178. }
  179. return;
  180. }
  181. function inject(options) {
  182. var target = gulp.src(options.htmlDest+'/'+options.htmlName);
  183. var sources = gulp.src(options.injectList, {read: false});
  184. return target.pipe($.plumber())
  185. .pipe($.inject(sources))
  186. .pipe(gulp.dest(options.htmlDest));
  187. }
  188. function htmlmin(options) {
  189. return gulp.src(options.htmlDest+'/*.html')
  190. // .pipe($.htmlmin({collapseWhitespace: true}))
  191. .pipe(gulp.dest(options.htmlDest));
  192. }
  193. gulp.task('minify', function (){
  194. return minify(commonOptions);
  195. });
  196. gulp.task('css',function () {
  197. return css(commonOptions);
  198. })
  199. gulp.task('common', ['minify','css']);
  200. gulp.task('login_minify',['common'], function (){
  201. return minify(loginOptions);
  202. });
  203. gulp.task('login_css',function () {
  204. return css(loginOptions);
  205. })
  206. gulp.task('login_inject',['login_minify','login_css'],function () {
  207. return inject(loginOptions);
  208. })
  209. gulp.task('login',['login_inject'], function (){
  210. return htmlmin(loginOptions);
  211. });
  212. gulp.task('header_minify',['common'], function (){
  213. return minify(headerOptions);
  214. });
  215. gulp.task('header_css',function () {
  216. return css(headerOptions);
  217. })
  218. gulp.task('header_inject',['header_minify','header_css'],function () {
  219. return inject(headerOptions);
  220. })
  221. gulp.task('header',['header_inject'], function (){
  222. return htmlmin(headerOptions);
  223. });
  224. gulp.task('pm_minify',['common'], function (){
  225. return minify(pmOptions);
  226. });
  227. gulp.task('pm_css',function () {
  228. return css(pmOptions);
  229. })
  230. gulp.task('pm_inject',['pm_minify','pm_css'],function () {
  231. return inject(pmOptions);
  232. })
  233. gulp.task('pm',['pm_inject'], function (){
  234. return htmlmin(pmOptions);
  235. });
  236. gulp.task('main_minify',['common'], function (){
  237. return minify(mainOptions);
  238. });
  239. gulp.task('main_css',function () {
  240. return css(mainOptions);
  241. })
  242. gulp.task('main_inject',['main_minify'],function () {//, ['main_minify','main_css' ] main css 打包到一起会出现样式冲突问题, 现改成不打包
  243. return inject(mainOptions);
  244. })
  245. gulp.task('main',['main_inject'], function (){
  246. return htmlmin(mainOptions);
  247. });
  248. gulp.task('compleGlj_minify', ['common'], function () {
  249. return minify(compleGljOptions);
  250. });
  251. gulp.task('compleGlj_css', function () {
  252. return css(compleGljOptions);
  253. });
  254. gulp.task('compleGlj_inject', ['compleGlj_minify', 'compleGlj_css'], function () {
  255. return inject(compleGljOptions);
  256. });
  257. gulp.task('compleGlj', ['compleGlj_inject'], function () {
  258. return htmlmin(compleGljOptions);
  259. });
  260. gulp.task('compleRation_ration_minify', ['common'], function () {
  261. return minify(compleRation_rationOptions);
  262. });
  263. gulp.task('compleRation_ration_css', function () {
  264. return css(compleRation_rationOptions);
  265. });
  266. gulp.task('compleRation_ration_inject', ['compleRation_ration_minify', 'compleRation_ration_css'], function () {
  267. return inject(compleRation_rationOptions);
  268. });
  269. gulp.task('compleRation_ration', ['compleRation_ration_inject'], function () {
  270. return htmlmin(compleRation_rationOptions);
  271. });
  272. gulp.task('compleRation_glj_minify', ['common'], function () {
  273. return minify(compleRation_gljOptions);
  274. });
  275. gulp.task('compleRation_glj_css', function () {
  276. return css(compleRation_gljOptions);
  277. });
  278. gulp.task('compleRation_glj_inject', ['compleRation_glj_minify', 'compleRation_glj_css'], function () {
  279. return inject(compleRation_gljOptions);
  280. });
  281. gulp.task('compleRation_glj', ['compleRation_glj_inject'], function () {
  282. return htmlmin(compleRation_gljOptions);
  283. });
  284. gulp.task('compleRation_coe_minify', ['common'], function () {
  285. return minify(compleRation_coeOptions);
  286. });
  287. gulp.task('compleRation_coe_css', function () {
  288. return css(compleRation_coeOptions);
  289. });
  290. gulp.task('compleRation_coe_inject', ['compleRation_coe_minify', 'compleRation_coe_css'], function () {
  291. return inject(compleRation_coeOptions);
  292. });
  293. gulp.task('compleRation_coe', ['compleRation_coe_inject'], function () {
  294. return htmlmin(compleRation_coeOptions);
  295. });
  296. gulp.task('compleRation_inst_minify', ['common'], function () {
  297. return minify(compleRation_instOptions);
  298. });
  299. gulp.task('compleRation_inst_css', function () {
  300. return css(compleRation_instOptions);
  301. });
  302. gulp.task('compleRation_inst_inject', ['compleRation_inst_minify', 'compleRation_inst_css'], function () {
  303. return inject(compleRation_instOptions);
  304. });
  305. gulp.task('compleRation_inst', ['compleRation_inst_inject'], function () {
  306. return htmlmin(compleRation_instOptions);
  307. });
  308. gulp.task('build',['header','login','pm','main', 'compleGlj', 'compleRation_ration', 'compleRation_glj', 'compleRation_coe', 'compleRation_inst']);