-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulpfile.js
178 lines (150 loc) · 5.6 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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
/* File: gulpfile.js */
// grab our packages
var gulp = require('gulp'),
jshint = require('gulp-jshint'),
sourcemaps = require('gulp-sourcemaps'),
concat = require('gulp-concat'),
gutil = require('gulp-util'),
browserSync = require('browser-sync').create(),
sass = require('gulp-ruby-sass'),
autoprefixer = require('gulp-autoprefixer'),
uglify = require('gulp-uglify'),
merge = require('merge-stream'),
cleanCSS = require('gulp-clean-css'),
babel = require('gulp-babel'),
del = require('del');
// TODO consider if it's necessary to have multiple paired cleaning and building
// tasks and if the path names should be vars (since they get re-used).
// Helper function to ensure certain functions are only invoked in the production
// environment.
function productionOnly(fn) {
return gutil.env.production ? fn() : gutil.noop();
}
// Helper function to ensure certain functions are only invoked in the development
// environment.
function devOnly(fn) {
return gutil.env.dev ? gutil.noop() : fn();
}
// define the default task and add the watch task to it
gulp.task('default', ['serve']);
// The reload-all task triggers the site building, starts up the reload server and
// starts watching for any changes to the source.
gulp.task('serve', ['reload-all'], function() {
// Serve files from the dist directory
browserSync.init({
server: {
baseDir: "./dist"
}
});
gulp.watch('src/js/**/*.js', ['reload-js']);
gulp.watch('src/css/**/*.css', ['reload-css']);
gulp.watch('src/scss/**/*.scss', ['reload-css']);
gulp.watch('src/html/**/*.html', ['reload-html']);
gulp.watch('src/assets/**/*', ['reload-assets']);
});
function jshintHelper() {
return gulp.src('src/js/**/*.js')
.pipe(jshint({esversion: 6})) // Since we're running the js through babel
// we don't need to worry about compatibility.
.pipe(jshint.reporter('jshint-stylish'));
}
// To make sure that the page reloads quickly, we don't want to waste time
// running jshint until the page has reloaded. To achieve this we have to
// have reload as a dependency for any task invoking jshint... which is a
// little odd because the two things are entirely independent, but that's how
// Gulp works.
// Also, reload() ends up getting called before the server has started.
// Fortunately this is a no-op.
gulp.task('reload-all', ['build-js', 'bundle-css', 'copy-html', 'copy-assets'], function() {
browserSync.reload();
jshintHelper();
});
// Delete the distribution.
gulp.task('clean', function() {
return del(['dist/*']);
});
// Specific cleaners
gulp.task('clean-html', function () {
return del(['dist/**/*.html']);
});
gulp.task('clean-css', function () {
return del(['dist/css/**/*']);
});
gulp.task('clean-js', function () {
return del(['dist/js/**/*']);
});
gulp.task('clean-assets', function () {
return del(['dist/assets/**/*']);
});
// no such file or directory, open '/home/oliver/Webdev/heroku/sample-sites/dist/assets/images/deck_builder_card_bg.png'
// Pre-process the css.
function processScss () {
return sass('src/scss/**/*.scss', {
sourcemap: true
})
.on('error', sass.logError)
.pipe(sourcemaps.write());
}
gulp.task('reload-css', ['bundle-css'], function () {
browserSync.reload();
})
// Separate scss processing task.
gulp.task('build-scss', ['clean-css'], function () {
return processScss()
.pipe(gulp.dest('dist/css'));
});
// Get the pre-processed scss, bundle it up with the existing css and add any
// mising prefixes.
gulp.task('bundle-css', ['clean-css'], function () {
return merge(processScss(), gulp.src('src/css/**/*.css'))
.pipe(autoprefixer())
.pipe(concat('bundle.min.css'))
.pipe(productionOnly(cleanCSS({compatibility: 'ie8'})))
.pipe(gulp.dest('dist/css'));
});
gulp.task('reload-js', ['build-js'], function () {
browserSync.reload();
jshintHelper();
})
// Bundle up and minify the javascript, including sourcemaps so that
// dev-tools can point you to the right js file.
// Since the project is relatively simple, I've not made use of requirejs (yet)
// The dependency management is straightforward - some files depend on the helpers
// so we must load the helpers first.
gulp.task('build-js', ['clean-js'], function () {
return gulp.src(['src/js/helpers/**/*.js','src/js/**/*.js'])
.pipe(sourcemaps.init())
.pipe(concat('bundle.min.js'))
// uglify cannot cope with es6 js, so we use babel to convert it first.
.pipe(babel({
presets: ['es2015']
}))
//only uglify if gulp is ran with '--type production'
//.pipe(gutil.env.type === 'production' ? uglify() : gutil.noop())
.pipe(uglify({
compress: {
pure_funcs: ['console.log', 'window.console.log'] // Tells uglify that console.log has
// no side-effects and, since its result is never used, can be
// safely deleted.
}
}))
//.pipe(devOnly(uglify))
.pipe(sourcemaps.write())
.pipe(gulp.dest('dist/js'));
});
gulp.task('reload-html', ['copy-html'], function () {
browserSync.reload();
});
// At the moment this is pretty trivial, but it allows us to torch the entire
// contents of the dist directory when we clean.
gulp.task('copy-html', ['clean-html'], function () {
return gulp.src('src/html/**/*.html')
.pipe(gulp.dest('dist'))
});
gulp.task('reload-assets', ['copy-assets'], function () {
browserSync.reload();
});
gulp.task('copy-assets', ['clean-assets'], function () {
return gulp.src('src/assets/**/*')
.pipe(gulp.dest('dist/assets'))
});