var gulp = require('gulp') var browserSync = require('browser-sync').create() var sass = require('gulp-sass') var autoprefixer = require('gulp-autoprefixer') var browserify = require('browserify') var source = require('vinyl-source-stream') var streamify = require('gulp-streamify') var babel = require('gulp-babel') var tap = require('gulp-tap') var buffer = require('gulp-buffer') var sourcemaps = require('gulp-sourcemaps') var del = require('del') var gutil = require('gulp-util') var uglify = require('gulp-uglify') var imagemin = require('gulp-imagemin') gulp.task('js', function () { return gulp.src('src/**/*.js', {read: false}) .pipe(sourcemaps.init({loadMaps: true})) .pipe(tap(function (file) { gutil.log('bundling ' + file.path) file.contents = browserify(file.path, {debug: true}).bundle() })) .pipe(streamify(babel({ presets: ['es2015', 'es2017'] }))) .pipe(buffer()) .pipe(uglify()) .pipe(sourcemaps.write('./')) .pipe(gulp.dest('dist')) .pipe(browserSync.stream()) }) gulp.task('html', function() { return gulp.src(['src/**/*.html']) .pipe(gulp.dest('dist')) }) gulp.task('sass', function() { return gulp.src("src/scss/main.scss") .pipe(sass()) .on('error', gutil.log) .pipe(autoprefixer({ browsers: ['last 3 versions'], cascade: false })) .pipe(gulp.dest("dist/css")) .pipe(browserSync.stream()) }) gulp.task('imagemin', function() { gulp.src('src/img/**/*') .pipe(imagemin()) .pipe(gulp.dest('dist/img')) }) gulp.task('clean', function() { del.sync('dist/*') }) gulp.task('develop', ['build'], function() { browserSync.init({server: "./"}) gulp.watch("src/scss/*.scss", ['sass']) gulp.watch("src/js/*.js", ['js']) gulp.watch("src/img/**/*", ['imagemin']) gulp.watch("./*.html").on('change', browserSync.reload) }) gulp.task('build', ['clean', 'sass', 'imagemin', 'js']) gulp.task('default', ['develop'])