-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
93 lines (80 loc) · 2.51 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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
var gulp = require('gulp'),
jade = require('gulp-jade'),
browserify = require('gulp-browserify'),
uglify = require('gulp-uglify'),
sass = require('gulp-sass'),
browserSync = require('browser-sync'),
gulpif = require('gulp-if');
var env = process.env.NODE_ENV || 'development';
var outputDir = 'builds/development';
function printError(error) {
console.log(error.toString());
this.emit('end');
}
gulp.task('jade', function() {
return gulp.src('src/templates/index.jade')
.pipe(jade())
.on('error', printError)
.pipe(gulp.dest(outputDir))
.pipe(browserSync.reload({stream: true}));
});
gulp.task('js', function() {
return gulp.src(['src/js/**/*.js', '!src/js/**/*.min.js'])
.pipe(browserify({ debug: env === 'development' }))
.on('error', printError)
.pipe(gulpif(env === 'production', uglify()))
.on('error', printError)
.pipe(gulp.dest(outputDir + '/js'))
.pipe(browserSync.reload({stream: true}))
});
gulp.task('js-min', function() {
return gulp.src('src/js/**/*.min.js')
.pipe(gulp.dest(outputDir + '/js'))
.pipe(browserSync.reload({stream: true}))
});
gulp.task('sass', function() {
var config = {};
if (env === 'development') {
config.sourceComments = 'map';
}
if (env === 'production') {
config.outputStyle = 'compressed';
}
return gulp.src('src/sass/main.scss')
.pipe(sass(config))
.on('error', printError)
.pipe(gulp.dest(outputDir + '/css'))
.pipe(browserSync.reload({stream: true}));
});
gulp.task('css-min', function() {
return gulp.src('src/css/**/*.min.css')
.pipe(gulp.dest(outputDir + '/css'))
.pipe(browserSync.reload({stream: true}));
});
gulp.task('favicon', function() {
return gulp.src('src/favicon.ico')
.pipe(gulp.dest(outputDir))
.pipe(browserSync.reload({stream: true}));
});
gulp.task('images', function() {
return gulp.src('src/images/**/*')
.pipe(gulp.dest(outputDir + '/images'))
.pipe(browserSync.reload({stream: true}));
});
gulp.task('watch', function() {
gulp.watch('src/templates/**/*.jade', ['jade']);
gulp.watch('src/js/**/*.js', ['js', 'js-min']);
gulp.watch('src/sass/**/*.scss', ['sass']);
gulp.watch('src/css/**/*.min.css', ['css-min']);
gulp.watch('src/favicon.ico' ['favicon']);
gulp.watch('src/images/**/*', ['images']);
});
gulp.task('browser-sync', function() {
browserSync({
server: {
baseDir: outputDir
},
port: 3000
});
});
gulp.task('default', ['js', 'js-min', 'jade', 'sass', 'css-min', 'favicon', 'images', 'watch', 'browser-sync']);