gulpfile.js 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. var gulp = require('gulp');
  2. var gulpLoadPlugins = require('gulp-load-plugins');
  3. var browserSync = require('browser-sync');
  4. var del = require('del');
  5. var fs = require('fs');
  6. var git = require('git-rev-sync');
  7. var tryFn = require('nice-try');
  8. var saveLicense = require('uglify-save-license');
  9. var $ = gulpLoadPlugins();
  10. var reload = browserSync.reload;
  11. gulp.task('clean', del.bind(null, ['.tmp', 'dist']));
  12. gulp.task('lint', function () {
  13. return gulp.src([
  14. 'src/scripts/**/*.js'
  15. ]).pipe(reload({stream: true, once: true}))
  16. .pipe($.eslint.format())
  17. .pipe($.if(!browserSync.active, $.eslint.failAfterError()))
  18. .pipe(gulp.dest('src/scripts'));
  19. });
  20. gulp.task('prepare-fonts', function () {
  21. return gulp.src([
  22. 'node_modules/font-awesome/fonts/fontawesome-webfont.*'
  23. ]).pipe(gulp.dest('.tmp/fonts'));
  24. });
  25. gulp.task('process-fonts', ['prepare-fonts'], function () {
  26. return gulp.src([
  27. '.tmp/fonts/**/*'
  28. ]).pipe(gulp.dest('dist/fonts'));
  29. });
  30. gulp.task('prepare-langs', function () {
  31. return gulp.src([
  32. 'src/langs/**/*'
  33. ]).pipe(gulp.dest('.tmp/langs'));
  34. });
  35. gulp.task('process-langs', ['prepare-langs'], function () {
  36. return gulp.src([
  37. '.tmp/langs/**/*'
  38. ]).pipe(gulp.dest('dist/langs'));
  39. });
  40. gulp.task('prepare-styles', function () {
  41. return gulp.src([
  42. 'src/styles/**/*.css'
  43. ]).pipe($.autoprefixer())
  44. .pipe(gulp.dest('.tmp/styles'))
  45. .pipe(reload({stream: true}));
  46. });
  47. gulp.task('prepare-scripts', function () {
  48. return gulp.src([
  49. 'src/scripts/**/*.js'
  50. ]).pipe($.plumber())
  51. .pipe($.injectVersion({replace: '${ARIANG_VERSION}'}))
  52. .pipe($.replace(/\${ARIANG_BUILD_COMMIT}/g, tryFn(git.short) || 'Local'))
  53. .pipe(gulp.dest('.tmp/scripts'))
  54. .pipe(reload({stream: true}));
  55. });
  56. gulp.task('prepare-views', function () {
  57. return gulp.src([
  58. 'src/views/**/*.html'
  59. ]).pipe($.htmlmin({collapseWhitespace: true}))
  60. .pipe($.angularTemplatecache({module: 'ariaNg', filename: 'views/templates.js', root: 'views/'}))
  61. .pipe(gulp.dest('.tmp/scripts'));
  62. });
  63. gulp.task('prepare-html', ['prepare-styles', 'prepare-scripts', 'prepare-views'], function () {
  64. return gulp.src([
  65. 'src/*.html'
  66. ]).pipe($.useref({searchPath: ['.tmp', 'src', '.']}))
  67. .pipe($.if('js/*.js', $.replace(/\/\/# sourceMappingURL=.*/g, '')))
  68. .pipe($.if('css/*.css', $.replace(/\/\*# sourceMappingURL=.* \*\/$/g, '')))
  69. .pipe($.if(['js/moment-with-locales-*.min.js', 'js/plugins.min.js', 'js/aria-ng.min.js'], $.uglify({output: {comments: saveLicense}})))
  70. .pipe($.if(['css/plugins.min.css', 'css/aria-ng.min.css'], $.cssnano({safe: true, autoprefixer: false})))
  71. .pipe($.replace(/url\((\.\.\/fonts\/[a-zA-Z0-9\-]+\.woff2)(\?[a-zA-Z0-9\-_=.]+)?\)/g, function(match, fileName) {
  72. return 'url(' + fileName + ')'; // remove version of woff2 file (woff2 file should be cached via application cache)
  73. }))
  74. .pipe($.if(['js/plugins.min.js', 'js/aria-ng.min.js', 'css/plugins.min.css', 'css/aria-ng.min.css'], $.rev()))
  75. .pipe($.if('*.html', $.htmlmin({collapseWhitespace: true})))
  76. .pipe($.revReplace())
  77. .pipe(gulp.dest('.tmp'));
  78. });
  79. gulp.task('process-html', ['prepare-html'], function () {
  80. return gulp.src([
  81. '.tmp/*.html'
  82. ]).pipe($.replace(/<!-- AriaNg-Bundle:\w+ -->/, ''))
  83. .pipe(gulp.dest('dist'));
  84. });
  85. gulp.task('process-assets', ['process-html'], function () {
  86. return gulp.src([
  87. '.tmp/css/**/*',
  88. '.tmp/js/**/*'
  89. ],{ base: '.tmp' })
  90. .pipe(gulp.dest('dist'));
  91. });
  92. gulp.task('prepare-assets-bundle', function () {
  93. return gulp.src([
  94. 'src/favicon.png'
  95. ]).pipe(gulp.dest('.tmp'));
  96. });
  97. gulp.task('process-assets-bundle', ['prepare-fonts', 'prepare-langs', 'prepare-html', 'prepare-assets-bundle'], function () {
  98. return gulp.src('.tmp/index.html')
  99. .pipe($.replace(/<link rel="stylesheet" href="(css\/[a-zA-Z0-9\-_.]+\.css)">/g, function(match, fileName) {
  100. var content = fs.readFileSync('.tmp/' + fileName, 'utf8');
  101. return '<style type="text/css">' + content + '</style>';
  102. }))
  103. .pipe($.replace(/<script src="(js\/[a-zA-Z0-9\-_.]+\.js)"><\/script>/g, function(match, fileName) {
  104. var content = fs.readFileSync('.tmp/' + fileName, 'utf8');
  105. return '<script type="application/javascript">' + content + '</script>';
  106. }))
  107. .pipe($.replace(/url\(\.\.\/(fonts\/[a-zA-Z0-9\-]+\.woff)(\?[a-zA-Z0-9\-_=.]+)?\)/g, function(match, fileName) {
  108. if (!fs.existsSync('.tmp/' + fileName)) {
  109. return match;
  110. }
  111. var contentBuffer = fs.readFileSync('.tmp/' + fileName);
  112. var contentBase64 = contentBuffer.toString('base64');
  113. return 'url(data:application/x-font-woff;base64,' + contentBase64 + ')';
  114. }))
  115. .pipe($.replace(/<link rel="icon" href="([a-zA-Z0-9\-_.]+\.png)">/g, function(match, fileName) {
  116. if (!fs.existsSync('.tmp/' + fileName)) {
  117. return match;
  118. }
  119. var contentBuffer = fs.readFileSync('.tmp/' + fileName);
  120. var contentBase64 = contentBuffer.toString('base64');
  121. return '<link rel="icon" href="data:image/png;base64,' + contentBase64 + '">';
  122. }))
  123. .pipe($.replace('<!-- AriaNg-Bundle:languages -->', function() {
  124. var langDir = '.tmp/langs/';
  125. var result = '';
  126. var fileNames = fs.readdirSync(langDir, 'utf8');
  127. if (fileNames.length > 0) {
  128. result = '<script type="application/javascript">' +
  129. 'angular.module("ariaNg").config(["ariaNgAssetsCacheServiceProvider",function(e){';
  130. for (var i = 0; i < fileNames.length; i++) {
  131. var fileName = fileNames[i];
  132. var content = fs.readFileSync(langDir + fileName, 'utf8');
  133. var lastPointIndex = fileName.lastIndexOf('.');
  134. var languageName = fileName.substr(0, lastPointIndex);
  135. content = content.replace(/\\/g, '\\\\');
  136. content = content.replace(/\r/g, '');
  137. content = content.replace(/\n/g, '\\n');
  138. content = content.replace(/"/g, '\\"');
  139. result += 'e.setLanguageAsset(\'' + languageName + '\',"' + content + '");';
  140. }
  141. result += '}]);</script>';
  142. }
  143. return result;
  144. }))
  145. .pipe($.replace(/<[a-z]+( [a-z\-]+="[a-zA-Z0-9\- ]+")* [a-z\-]+="((favicon.ico)|(tileicon.png)|(touchicon.png))"\/?>/g, ''))
  146. .pipe(gulp.dest('dist'));
  147. });
  148. gulp.task('process-full-extras', function () {
  149. return gulp.src([
  150. 'LICENSE',
  151. 'src/*.*',
  152. '!src/*.html'
  153. ], {
  154. dot: true
  155. }).pipe(gulp.dest('dist'));
  156. });
  157. gulp.task('process-tiny-extras', function () {
  158. return gulp.src([
  159. 'LICENSE'
  160. ]).pipe(gulp.dest('dist'));
  161. });
  162. gulp.task('info', function () {
  163. return gulp.src([
  164. 'dist/**/*'
  165. ]).pipe($.size({title: 'build', gzip: true}));
  166. });
  167. gulp.task('build', $.sequence('lint', 'process-fonts', 'process-langs', 'process-assets', 'process-full-extras', 'info'));
  168. gulp.task('build-bundle', $.sequence('lint', 'process-assets-bundle', 'process-tiny-extras', 'info'));
  169. gulp.task('serve', ['prepare-styles', 'prepare-scripts', 'prepare-fonts'], function () {
  170. browserSync({
  171. notify: false,
  172. port: 9000,
  173. server: {
  174. baseDir: ['.tmp', 'src'],
  175. routes: {
  176. '/node_modules': 'node_modules'
  177. }
  178. }
  179. });
  180. gulp.watch([
  181. 'src/*.html',
  182. 'src/*.ico',
  183. 'src/*.png',
  184. 'src/langs/*.txt',
  185. 'src/views/*.html',
  186. 'src/imgs/**/*',
  187. '.tmp/fonts/**/*'
  188. ]).on('change', reload);
  189. gulp.watch('src/styles/**/*.css', ['prepare-styles']);
  190. gulp.watch('src/scripts/**/*.js', ['prepare-scripts']);
  191. gulp.watch('src/fonts/**/*', ['prepare-fonts']);
  192. });
  193. gulp.task('serve:dist', function () {
  194. browserSync({
  195. notify: false,
  196. port: 9000,
  197. server: {
  198. baseDir: ['dist']
  199. }
  200. });
  201. });
  202. gulp.task('default', ['clean'], function () {
  203. gulp.start('build');
  204. });