cn.status.im/gulpfile.js

79 lines
2.3 KiB
JavaScript
Executable File

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 rename = require('gulp-rename')
var uglify = require('gulp-uglify')
var htmlmin = require('gulp-htmlmin')
var imagemin = require('gulp-imagemin')
gulp.task('js', function () {
return gulp.src('src/js/**/*.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/js'))
.pipe(browserSync.stream())
})
gulp.task('fonts', function() {
return gulp.src(['src/fonts**/*'])
.pipe(gulp.dest('dist'))
})
gulp.task('html', function() {
return gulp.src(['src/**/*.html'])
.pipe(htmlmin({collapseWhitespace: true, minifyJS: true}))
.pipe(rename(p => p.dirname = p.dirname.slice(5)))
.pipe(gulp.dest('dist'))
})
gulp.task('css', 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('images', 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: "./dist"})
gulp.watch("src/scss/*.scss", ['css'])
gulp.watch("src/js/*.js", ['js'])
gulp.watch("src/img/**/*", ['images'])
gulp.watch("./*.html", ['html']).on('change', browserSync.reload)
})
gulp.task('build', ['clean', 'css', 'images', 'fonts', 'js', 'html'])
gulp.task('default', ['develop'])