gulpfile.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. 'use strict';
  2. require('cache-require-paths');
  3. var gulp = require('gulp');
  4. var babelify = require('babelify');
  5. var browserify = require('browserify');
  6. var buffer = require('vinyl-buffer');
  7. var imageop = require('gulp-image-optimization');
  8. var jshint = require('gulp-jshint');
  9. var less = require('gulp-less');
  10. var minify = require('gulp-minify-css');
  11. var rename = require('gulp-rename');
  12. var source = require('vinyl-source-stream');
  13. var sourcemaps = require('gulp-sourcemaps');
  14. var uglify = require('gulp-uglify');
  15. var glob = require('glob');
  16. var del = require('del');
  17. var misago = '../misago/static/misago/';
  18. // Entry points
  19. gulp.task('watch', ['fastbuild'], function() {
  20. gulp.watch('src/**/*.js', ['fastsource']);
  21. gulp.watch('style/**/*.less', ['faststyle']);
  22. });
  23. // Builds
  24. gulp.task('fastbuild', [
  25. 'fastsource', 'faststyle', 'faststatic', 'fastvendorsources', 'copyvendors'
  26. ]);
  27. gulp.task('build', [
  28. 'source', 'style', 'static', 'vendorsources', 'copyvendors'
  29. ]);
  30. // Source tasks
  31. function getSources() {
  32. var sources = ['src/index.js'];
  33. function include(pattern) {
  34. var paths = glob.sync(pattern);
  35. paths.forEach(function(path) {
  36. sources.push(path);
  37. });
  38. };
  39. include('src/initializers/*.js');
  40. return sources.map(function(path) {
  41. return path;
  42. });
  43. };
  44. gulp.task('lintsource', function() {
  45. return gulp.src('src/**/*.js')
  46. .pipe(jshint())
  47. .pipe(jshint.reporter('default'));
  48. });
  49. gulp.task('fastsource', ['lintsource'], function() {
  50. return browserify({
  51. entries: getSources(),
  52. debug: true
  53. })
  54. .external('moment')
  55. .external('react')
  56. .external('react-dom')
  57. .external('redux')
  58. .external('react-redux')
  59. .transform(babelify)
  60. .bundle()
  61. .pipe(source('misago.js'))
  62. .pipe(buffer())
  63. .pipe(gulp.dest(misago + 'js'));
  64. });
  65. gulp.task('source', ['lintsource'], function() {
  66. process.env.NODE_ENV = 'production';
  67. return browserify({
  68. entries: getSources(),
  69. debug: false
  70. })
  71. .external('moment')
  72. .external('react')
  73. .external('react-dom')
  74. .external('redux')
  75. .external('react-redux')
  76. .transform(babelify)
  77. .bundle()
  78. .pipe(source('misago.js'))
  79. .pipe(buffer())
  80. .pipe(sourcemaps.init())
  81. .pipe(uglify())
  82. .pipe(sourcemaps.write('.'))
  83. .pipe(gulp.dest(misago + 'js'));
  84. });
  85. // Styles tasks
  86. gulp.task('cleanstyle', function(cb) {
  87. del(misago + 'css', cb);
  88. });
  89. gulp.task('faststyle', function() {
  90. return gulp.src('style/index.less')
  91. .pipe(less())
  92. .pipe(rename('misago.css'))
  93. .pipe(gulp.dest(misago + 'css'));
  94. });
  95. gulp.task('style', function() {
  96. return gulp.src('style/index.less')
  97. .pipe(less())
  98. .pipe(minify())
  99. .pipe(rename('misago.css'))
  100. .pipe(gulp.dest(misago + 'css'));
  101. });
  102. // Static tasks
  103. gulp.task('copyfonts', function(cb) {
  104. return gulp.src('static/fonts/**/*')
  105. .pipe(gulp.dest(misago + 'fonts'));
  106. });
  107. gulp.task('fastcopyimages', function() {
  108. return gulp.src('static/img/**/*')
  109. .pipe(gulp.dest(misago + 'img'));
  110. });
  111. gulp.task('copyimages', function() {
  112. return gulp.src('static/img/**/*')
  113. .pipe(imageop({
  114. optimizationLevel: 9
  115. }))
  116. .pipe(gulp.dest(misago + 'img'));
  117. });
  118. gulp.task('faststatic', ['copyfonts', 'fastcopyimages']);
  119. gulp.task('static', ['copyfonts', 'copyimages']);
  120. // Vendor tasks
  121. gulp.task('fastvendorsources', function() {
  122. return browserify({
  123. entries: 'src/vendor.js',
  124. debug: true
  125. })
  126. .transform('browserify-shim')
  127. .require('moment')
  128. .require('react')
  129. .require('react-dom')
  130. .require('redux')
  131. .require('react-redux')
  132. .bundle()
  133. .pipe(source('vendor.js'))
  134. .pipe(buffer())
  135. .pipe(gulp.dest(misago + 'js'));
  136. });
  137. gulp.task('vendorsources', function() {
  138. process.env.NODE_ENV = 'production';
  139. return browserify({
  140. entries: 'src/vendor.js',
  141. debug: false
  142. })
  143. .require('moment')
  144. .require('react')
  145. .require('react-dom')
  146. .require('redux')
  147. .require('react-redux')
  148. .transform(babelify)
  149. .bundle()
  150. .pipe(source('vendor.js'))
  151. .pipe(buffer())
  152. .pipe(sourcemaps.init())
  153. .pipe(uglify())
  154. .pipe(sourcemaps.write('.'))
  155. .pipe(gulp.dest(misago + 'js'));
  156. });
  157. gulp.task('copyvendors', function() {
  158. return gulp.src([
  159. 'zxcvbn/dist/*'
  160. ].map(function(item) {
  161. return 'node_modules/' + item;
  162. }))
  163. .pipe(gulp.dest(misago + 'js'));
  164. });
  165. // Test task
  166. gulp.task('linttests', function() {
  167. return gulp.src(['tests/**/*.js'])
  168. .pipe(jshint())
  169. .pipe(jshint.reporter('default'));
  170. });
  171. gulp.task('test', ['linttests', 'lintsource'], function() {
  172. var mochify = require('mochify');
  173. mochify('src/test-setup.js tests/**/*.js')
  174. .transform(babelify)
  175. .bundle();
  176. });