gulpfile.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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'
  26. ]);
  27. gulp.task('build', [
  28. 'source', 'style', 'static', 'vendorsources'
  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. include('src/components/*.js');
  41. include('src/components/**/root.js');
  42. return sources.map(function(path) {
  43. return path;
  44. });
  45. };
  46. gulp.task('lintsource', function() {
  47. return gulp.src('src/**/*.js')
  48. .pipe(jshint())
  49. .pipe(jshint.reporter('default'));
  50. });
  51. gulp.task('fastsource', ['lintsource'], function() {
  52. return browserify({
  53. entries: getSources(),
  54. debug: true
  55. })
  56. .external('react')
  57. .external('react-dom')
  58. .external('redux')
  59. .external('react-redux')
  60. .transform(babelify)
  61. .bundle()
  62. .pipe(source('misago.js'))
  63. .pipe(buffer())
  64. .pipe(gulp.dest(misago + 'js'));
  65. });
  66. gulp.task('source', ['lintsource'], function() {
  67. process.env.NODE_ENV = 'production';
  68. return browserify({
  69. entries: getSources(),
  70. debug: false
  71. })
  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('react')
  128. .require('react-dom')
  129. .require('redux')
  130. .require('react-redux')
  131. .bundle()
  132. .pipe(source('vendor.js'))
  133. .pipe(buffer())
  134. .pipe(gulp.dest(misago + 'js'));
  135. });
  136. gulp.task('vendorsources', function() {
  137. process.env.NODE_ENV = 'production';
  138. return browserify({
  139. entries: 'src/vendor.js',
  140. debug: false
  141. })
  142. .require('react')
  143. .require('react-dom')
  144. .require('redux')
  145. .require('react-redux')
  146. .transform(babelify)
  147. .bundle()
  148. .pipe(source('vendor.js'))
  149. .pipe(buffer())
  150. .pipe(sourcemaps.init())
  151. .pipe(uglify())
  152. .pipe(sourcemaps.write('.'))
  153. .pipe(gulp.dest(misago + 'js'));
  154. });
  155. // Test task
  156. gulp.task('linttests', function() {
  157. return gulp.src(['tests/**/*.js'])
  158. .pipe(jshint())
  159. .pipe(jshint.reporter('default'));
  160. });
  161. gulp.task('test', ['linttests', 'lintsource'], function() {
  162. var mochify = require('mochify');
  163. mochify('tests/**/*.js')
  164. .transform(babelify)
  165. .bundle();
  166. });