const {series, parallel, watch, src, dest} = require('gulp'); const pump = require('pump'); const fs = require('fs'); const order = require('ordered-read-streams'); // gulp plugins and utils const livereload = require('gulp-livereload'); const postcss = require('gulp-postcss'); const concat = require('gulp-concat'); const uglify = require('gulp-uglify'); const beeper = require('beeper'); const zip = require('gulp-zip'); // postcss plugins const easyimport = require('postcss-easy-import'); const autoprefixer = require('autoprefixer'); const cssnano = require('cssnano'); function serve(done) { livereload.listen(); done(); } function handleError(done) { return function (err) { if (err) { beeper(); } return done(err); }; }; function hbs(done) { pump([ src(['*.hbs', 'partials/**/*.hbs']), livereload() ], handleError(done)); } function css(done) { pump([ src('assets/css/screen.css', {sourcemaps: true}), postcss([ easyimport, autoprefixer(), cssnano() ]), dest('assets/built/', {sourcemaps: '.'}), livereload() ], handleError(done)); } function getJsFiles(version) { const jsFiles = [ src(`node_modules/@tryghost/shared-theme-assets/assets/js/${version}/lib/**/*.js`), src(`node_modules/@tryghost/shared-theme-assets/assets/js/${version}/main.js`), ]; if (fs.existsSync(`assets/js/lib`)) { jsFiles.push(src(`assets/js/lib/*.js`)); } jsFiles.push(src(`assets/js/main.js`)); return jsFiles; } function js(done) { pump([ order(getJsFiles('v1'), {sourcemaps: true}), concat('main.min.js'), uglify(), dest('assets/built/', {sourcemaps: '.'}), livereload() ], handleError(done)); } function zipper(done) { const filename = require('./package.json').name + '.zip'; pump([ src([ '**', '!node_modules', '!node_modules/**', '!dist', '!dist/**', '!yarn-error.log' ]), zip(filename), dest('dist/') ], handleError(done)); } const hbsWatcher = () => watch(['*.hbs', 'partials/**/*.hbs'], hbs); const cssWatcher = () => watch('assets/css/**/*.css', css); const jsWatcher = () => watch('assets/js/**/*.js', js); const watcher = parallel(hbsWatcher, cssWatcher, jsWatcher); const build = series(css, js); exports.build = build; exports.zip = series(build, zipper); exports.default = series(build, serve, watcher);