-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
73 lines (60 loc) · 1.85 KB
/
gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
"use strict";
//------------------------------
// Plugins & dependencies
//------------------------------
const gulp = require( "gulp" );
// JavaScript bundling
const browserify = require( "browserify" ),
uglify = require( "gulp-uglify" ),
babelify = require('babelify');
// Utilities
const source = require( "vinyl-source-stream" ),
buffer = require( "vinyl-buffer" ),
sourcemaps = require( "gulp-sourcemaps" ),
log = require( "gulplog" );
// CSS
const sass = require( "gulp-sass" ),
autoprefixer = require( "gulp-autoprefixer" );
//------------------------------------------
// Javascript bundling and transforms
//------------------------------------------
gulp.task( "js", function () {
return browserify( "./src/scripts/app.js" )
.transform( "babelify", {
presets: [ "env" ]
})
.on( "error", log.error )
.bundle()
.pipe( source( "bundle.js" ))
.pipe( buffer())
.pipe( uglify())
.on( "error", log.error )
.pipe( gulp.dest( "./dist/scripts/" ));
});
//--------------------------------------
// Sass compiling, and autoprefix
//--------------------------------------
gulp.task( "sass", function() {
return gulp.src( "./src/styles/**/*.scss" )
.pipe( sourcemaps.init() )
.pipe( sass( {
outputStyle: "compressed"
}).on( "error", sass.logError ))
.pipe( autoprefixer( {
browsers: [ "last 2 versions" ],
cascade: false
}))
.pipe( sourcemaps.write( "./" ))
.pipe( gulp.dest( "./dist/styles/" ));
});
//-------------------
// Watch tasks
//-------------------
gulp.task( "watch", function() {
gulp.watch( "./src/scripts/**/*.js", [ "js" ] );
gulp.watch( "./src/styles/**/*.scss", [ "sass" ] );
});
//--------------------
// Default task
//--------------------
gulp.task( "default", [ "js", "sass" ] );