gulpfile.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. const path = require('path')
  2. const gulp = require('gulp')
  3. const postcss = require('gulp-postcss')
  4. const concat = require('gulp-concat')
  5. const cleanCSS = require('gulp-clean-css')
  6. const del = require('del')
  7. const outputPath = path.join(__dirname, 'static')
  8. const resourcesPath = path.join(__dirname, 'resources')
  9. const sourcePath = path.join(__dirname, 'src')
  10. const resourceFilePath = path.join(resourcesPath, '**')
  11. const tailwind = {
  12. paths: [path.join(__dirname, 'tailwind.css'), path.join(sourcePath, '**/*.css')],
  13. outputDir: path.join(outputPath, 'css'),
  14. outputName: 'tailwind.build.css',
  15. }
  16. const css = {
  17. watchCSS() {
  18. return gulp.watch(tailwind.paths, { ignoreInitial: false }, css._buildTailwind)
  19. },
  20. buildCSS(...params) {
  21. return gulp.series(css._buildTailwind, css._optimizeCSSForRelease)(...params)
  22. },
  23. _buildTailwind() {
  24. return gulp.src(tailwind.paths)
  25. .pipe(postcss())
  26. .pipe(concat(tailwind.outputName))
  27. .pipe(gulp.dest(tailwind.outputDir))
  28. },
  29. _optimizeCSSForRelease() {
  30. return gulp.src(path.join(outputPath, 'css', 'style.css'))
  31. .pipe(cleanCSS())
  32. .pipe(gulp.dest(outputPath))
  33. },
  34. }
  35. const common = {
  36. clean() {
  37. return del(outputPath)
  38. },
  39. syncResourceFile() {
  40. return gulp.src(resourceFilePath).pipe(gulp.dest(outputPath))
  41. },
  42. keepSyncResourceFile() {
  43. return gulp.watch(resourceFilePath, { ignoreInitial: false }, common.syncResourceFile)
  44. }
  45. }
  46. exports.clean = common.clean
  47. exports.watch = gulp.parallel(common.keepSyncResourceFile, css.watchCSS)
  48. exports.build = gulp.series(common.syncResourceFile, css.buildCSS)