-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
60 lines (49 loc) · 1.53 KB
/
gulpfile.js
File metadata and controls
60 lines (49 loc) · 1.53 KB
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
// GULP PLUGINS
var gulp = require('gulp'),
autoprefixer = require('gulp-autoprefixer'),
plumber = require('gulp-plumber'),
rename = require('gulp-rename'),
sass = require('gulp-sass'),
sourcemaps = require('gulp-sourcemaps'),
uglify = require('gulp-uglify'),
watch = require('gulp-watch');
// BASE ASSET DIRECTORY
var assetsDir = process.env.GULP_PATH;
var assets = {
js: [
assetsDir + "js/*.js",
'!' + assetsDir + 'js/*.min.js',
'!' + assetsDir + 'js/*.map'
],
sass: {
all: [assetsDir + "sass/**/*"],
main: [assetsDir + 'sass/*.scss']
}
}
// JAVASCRIPT
gulp.task( 'js', function(){
gulp.src( assets.js )
.pipe( plumber() )
.pipe( sourcemaps.init() )
.pipe( uglify({warnings: true}) )
.pipe( rename({suffix:'.min'}) )
.pipe( sourcemaps.write('.'))
.pipe( gulp.dest( assetsDir + 'js/' ) );
});
// BUILD SASS (SCSS)
gulp.task( 'sass', function(){
gulp.src( assets.sass.main )
.pipe( plumber() )
.pipe( sourcemaps.init() )
.pipe( sass({outputStyle: 'compressed', includePaths: [assetsDir + '/vendor/', assetsDir + '/vendor/bower_components/']}) )
.pipe( autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4', 'Firefox >= 4'))
.pipe( sourcemaps.write('.') )
.pipe( gulp.dest( assetsDir + 'css/' ) );
});
// GULP WATCH
gulp.task( 'watchAll', function(){
watch( assets.js, function() { gulp.run('js') } );
watch( assets.sass.all, function() { gulp.run('sass') } );
});
// DEFAULT TASK - keep watch at end of array
gulp.task( 'default', [ 'js', 'sass', 'watchAll' ] );