-
Notifications
You must be signed in to change notification settings - Fork 3
/
gulpfile.js
69 lines (60 loc) · 2.67 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
// Requiring Gulp
var gulp = require('gulp'),
sass = require('gulp-sass'), // Requiring gulp-sass (compiles SCSS)
sourcemaps = require('gulp-sourcemaps'), // Requiring sourcemaps (helps working locally)
autoprefixer = require('gulp-autoprefixer'), // Requiring autoprefixer (adds browser prefixes)
cssnano = require('gulp-cssnano'), // Requiring cssnano (minifies CSS)
imagemin = require('gulp-imagemin'), // Requiring imagemin (lossless image optimization)
browserSync = require('browser-sync'), // Requiring browser-sync (browser refresh)
shell = require('gulp-shell'), // Requiring gulp-shell (used for KSS node)
kssNode = 'node ' + __dirname + '/node_modules/kss/bin/kss-node '; // Require kss-node
// Start KSS (style guide) task
gulp.task('kss', shell.task(
[kssNode + '--config source/kss-config.json']));
// [kssNode + '--xdemo']));
// Start browserSync server
gulp.task('browserSync', function() {
browserSync({
// Display the build folder first
startPath: 'styleguide',
server: {
// Start in root (important for relative paths between build and style guide folders)
baseDir: ''
}
})
})
// Start stylesheets task
gulp.task('stylesheets', function() {
gulp.src('source/assets/stylesheets/*.scss') // Get all *.scss files
.pipe(sourcemaps.init()) // Initialize sourcemap plugin
.pipe(sass().on('error', sass.logError)) // Compiling sass
.pipe(autoprefixer('last 2 version')) // Adding browser prefixes
.pipe(sourcemaps.write()) // Writing sourcemaps
.pipe(cssnano()) // Compress
.pipe(gulp.dest('build/assets/stylesheets'))
.pipe(browserSync.reload({
stream: true
}));
})
// Start scripts task
gulp.task('scripts', function() {
gulp.src(['source/assets/scripts/main.js'])
.pipe(gulp.dest('build/assets/scripts'));
});
// Start images task
gulp.task('images', function() {
gulp.src('source/assets/images/**')
.pipe(imagemin())
.pipe(gulp.dest('build/assets/images'));
});
// Start watch groups of tasks
gulp.task('default', ['browserSync', 'stylesheets', 'images', 'scripts', 'kss'], function() {
gulp.watch('source/assets/stylesheets/**/*.scss', ['stylesheets']); // Watch for SCSS changes
gulp.watch('source/assets/images/**/*', ['images']); // Watch for image changes
gulp.watch('source/assets/scripts/**/*.js', ['scripts']); // Watch for JS changes
gulp.watch('source/**', ['kss']); // Watch for style guide changes
gulp.watch('build/**.html', browserSync.reload);
gulp.watch('styleguide/**.html', browserSync.reload);
});
// Start build task
gulp.task('build', ['stylesheets', 'images', 'scripts', 'kss'], function() {})