gulpfile.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. const gulp = require('gulp')
  2. const zip = require('gulp-zip')
  3. const sass = require('gulp-sass')
  4. const babel = require('gulp-babel')
  5. const qunit = require('gulp-qunit')
  6. const header = require('gulp-header')
  7. const eslint = require('gulp-eslint')
  8. const uglify = require('gulp-uglify')
  9. const rename = require('gulp-rename')
  10. const minify = require('gulp-clean-css')
  11. const connect = require('gulp-connect')
  12. const autoprefixer = require('gulp-autoprefixer')
  13. const yargs = require('yargs')
  14. const pkg = require('./package.json')
  15. const webpack = require('webpack-stream');
  16. const root = yargs.argv.root || '.'
  17. const port = yargs.argv.port || 8000
  18. const license = `/*!
  19. * reveal.js <%= pkg.version %> (<%= new Date().toDateString() %>)
  20. * <%= pkg.homepage %>
  21. * MIT licensed
  22. *
  23. * Copyright (C) 2020 Hakim El Hattab, https://hakim.se
  24. */\n`
  25. gulp.task('js', () => gulp.src(['./js/index.js'])
  26. .pipe(babel({ presets: ['@babel/preset-env'] }))
  27. .pipe(webpack({
  28. mode: 'production'
  29. }))
  30. .pipe(header(license, {pkg: pkg}))
  31. .pipe(rename('reveal.min.js'))
  32. .pipe(gulp.dest('./dist')))
  33. gulp.task('css-themes', () => gulp.src(['./css/theme/source/*.{sass,scss}'])
  34. .pipe(sass())
  35. .pipe(gulp.dest('./dist/theme')))
  36. gulp.task('css-print', () => gulp.src(['./css/print/*.{sass,scss,css}'])
  37. .pipe(sass())
  38. .pipe(gulp.dest('./dist/print')))
  39. gulp.task('css-core', gulp.series(
  40. () => gulp.src(['css/reveal.scss'])
  41. .pipe(sass())
  42. .pipe(autoprefixer())
  43. .pipe(gulp.dest('./dist')),
  44. () => gulp.src(['dist/reveal.css'])
  45. .pipe(minify({
  46. compatibility: 'ie9'
  47. }))
  48. .pipe(header(license, {pkg: pkg}))
  49. .pipe(gulp.dest('./dist'))
  50. ))
  51. gulp.task('css', gulp.parallel('css-themes', 'css-print', 'css-core'))
  52. gulp.task('test', gulp.series(
  53. () => gulp.src(['./js/reveal.js', 'gulpfile.js']).pipe(eslint()).pipe(eslint.format())
  54. // () => gulp.src(['./test/*.html']).pipe(qunit())
  55. ))
  56. gulp.task('default', gulp.series(gulp.parallel('js', 'css'), 'test'))
  57. gulp.task('package', gulp.series('default', () =>
  58. gulp.src([
  59. './index.html',
  60. './dist/**',
  61. './lib/**',
  62. './images/**',
  63. './plugin/**',
  64. './**.md'
  65. ]).pipe(zip('reveal-js-presentation.zip')).pipe(gulp.dest('./'))
  66. ))
  67. gulp.task('serve', () => {
  68. connect.server({
  69. root: root,
  70. port: port,
  71. livereload: true
  72. })
  73. gulp.watch(['js/**/*'], gulp.series('js', 'test'))
  74. gulp.watch([
  75. 'css/theme/source/*.{sass,scss}',
  76. 'css/theme/template/*.{sass,scss}',
  77. ], gulp.series('css-themes'))
  78. gulp.watch(['css/print/*.{sass,scss,css}'], gulp.series('css-print'))
  79. gulp.watch(['css/reveal.scss'], gulp.series('css-core'))
  80. })