yuzu-emu.github.io/gulpfile.js
2018-01-04 00:22:29 -05:00

121 lines
3.7 KiB
JavaScript

const fs = require('fs');
const exec = require('child_process').exec;
const gulp = require('gulp');
const util = require('gulp-util');
const merge = require('merge-stream');
const runSequence = require('run-sequence');
const sass = require('gulp-sass');
const postcss = require('gulp-postcss');
const cssnano = require('cssnano');
const concat = require('gulp-concat');
const imageResize = require('gulp-image-resize');
const browserSync = require('browser-sync').create();
const baseUrl = 'https://yuzu-emu.org';
const cname = 'yuzu-emu.org';
let finalCommand = null;
// Gulp Run Tasks
gulp.task('default', ['start:setup'], callback => {
runSequence('hugo', finalCommand, callback);
});
gulp.task('all', ['start:setup'], callback => {
runSequence(['assets:js', 'assets:scss'],
'hugo',
'assets:images',
finalCommand,
callback);
});
gulp.task('assets', ['start:setup'], callback => {
runSequence(['assets:js', 'assets:scss'], 'hugo', 'assets:images', finalCommand, callback);
});
// Gulp Pipeline
gulp.task('start:setup', () => {
if (util.env.production) {
process.env.HUGO_ENV = 'PRD';
process.env.HUGO_BASEURL = baseUrl;
finalCommand = 'final:publish';
} else {
process.env.HUGO_ENV = 'DEV';
process.env.HUGO_BASEURL = 'http://localhost:3000';
finalCommand = 'final:serve';
}
util.log(`process.env.HUGO_ENV = '${process.env.HUGO_ENV}'`);
util.log(`process.env.HUGO_BASEURL = '${process.env.HUGO_BASEURL}'`);
});
gulp.task('assets:images', () => {
const baseImages = gulp.src(`build/images/*`, {base: './'})
.pipe(gulp.dest('./'));
const jumbotronImages = gulp.src(`build/images/jumbotron/*`, {base: './'})
.pipe(imageResize({width: 786, height: 471, crop: true}))
.pipe(gulp.dest('./'));
const bannerImages = gulp.src(`build/images/banners/*`, {base: './'})
.pipe(imageResize({width: 824, height: 306, crop: false}))
.pipe(gulp.dest('./'));
const boxartImages = gulp.src(`build/images/game/boxart/*`, {base: './'})
.pipe(imageResize({width: 328, height: 300, crop: true}))
.pipe(gulp.dest('./'));
const iconImages = gulp.src(`build/images/game/icons/*`, {base: './'})
.pipe(imageResize({width: 48, height: 48, crop: true}))
.pipe(gulp.dest('./'));
const screenshotImages = gulp.src(`build/images/screenshots/*`)
.pipe(imageResize({width: 400, height: 240, crop: false}))
.pipe(gulp.dest(`build/images/screenshots/thumbs`));
return merge(baseImages, jumbotronImages, bannerImages, boxartImages, iconImages, screenshotImages);
});
gulp.task('assets:js', () => {
return gulp.src(['src/js/**/*.js'])
.pipe(concat('script.js'))
.pipe(gulp.dest('build/js'));
});
gulp.task('assets:scss', () => {
const postCssOptions = [cssnano];
return gulp.src('src/scss/style.scss')
.pipe(sass().on('error', sass.logError))
.pipe(postcss(postCssOptions))
.pipe(gulp.dest('build/css'))
.pipe(browserSync.stream());
});
gulp.task('hugo', cb => {
exec('hugo -s ./site/ -d ../build/ -v', (err, stdout, stderr) => {
console.log(stdout);
console.log(stderr);
cb(err);
});
});
function fileChange(x) {
console.log(`[FileChange] File changed: ${x.path}`);
browserSync.reload(x);
}
gulp.task('final:serve', () => {
browserSync.init({
open: false,
server: {
baseDir: 'build'
}
});
gulp.watch('src/js/**/*', ['assets:js']);
gulp.watch('src/scss/**/*', ['assets:scss']);
gulp.watch('site/**/*.html', ['hugo']);
gulp.watch('site/**/*.md', ['hugo']);
gulp.watch('build/**/*').on('change', fileChange);
});
gulp.task('final:publish', () => {
fs.writeFileSync(`build/CNAME`, `${cname}`);
fs.writeFileSync(`build/robots.txt`, `Sitemap: https://${cname}/sitemap.xml\n\nUser-agent: *`);
});