-
Notifications
You must be signed in to change notification settings - Fork 46
Expand file tree
/
Copy pathgulpfile.js
More file actions
145 lines (127 loc) · 3.72 KB
/
gulpfile.js
File metadata and controls
145 lines (127 loc) · 3.72 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
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
// Define variables.
const gulp = require('gulp');
const autoprefixer = require('autoprefixer');
const postcss = require('gulp-postcss');
const cssvariables = require('postcss-css-variables');
const sass = require('gulp-sass');
const plumber = require('gulp-plumber');
const browsersync = require('browser-sync').create();
const sourcemaps = require('gulp-sourcemaps');
const cssnano = require('cssnano');
const rename = require('gulp-rename');
const run = require('gulp-run');
const del = require('del');
const concat = require('gulp-concat');
const uglify = require('gulp-uglify');
// BrowserSync
const browserSyncConfig = {
server: '_site/',
ghostMode: true,
logFileChanges: true,
open: true,
port: 3000,
files: [
'./_src/cssans/sass/**/*.scss',
'./_src/site/sass/**/*.scss'
],
}
// BrowserSync Start
function browserSync() {
browsersync.init(browserSyncConfig);
}
// BrowserSync Reload
function browserSyncReload(done) {
browsersync.reload();
done();
}
// Clean Assets
function clean() {
return del(['_includes/assets/', 'dist', '_site']);
}
// Main CSS task.
// This watches both the site CSS and CSSans
function cssSite() {
return gulp
// Dev version
.src('./_src/site/sass/**/*.scss')
.pipe(sourcemaps.init())
.pipe(plumber())
.pipe(sass({ outputStyle: 'expanded' }))
.pipe(sourcemaps.write())
.pipe(gulp.dest('./_min/'))
.pipe(gulp.dest('./_site/_min/')) /* Update _site for live reloading */
// Prod version
.pipe(rename({ suffix: '.min' }))
.pipe(postcss([autoprefixer(), cssnano()]))
.pipe(gulp.dest('./_includes/assets/'));
}
// CSSans only task
// outputs to dist/folder
function cssans() {
return gulp
.src('./_src/cssans/sass/**/*.scss')
.pipe(plumber())
.pipe(sass({ outputStyle: 'expanded' }))
// Prod version
.pipe(rename({ suffix: '.min' }))
.pipe(postcss([autoprefixer(), cssnano()]))
.pipe(gulp.dest("./dist/"))
// IE version (doesn't support CSS vars)
.pipe(rename({ suffix: ".ie" }))
.pipe(postcss([cssvariables]))
.pipe(gulp.dest('./dist/'));
}
// Concatenate and minify site scripts
function scriptsSite() {
return (
gulp
.src(['./_src/cssans/js/**/*.js', './_src/site/js/**/*.js'])
.pipe(concat('main.min.js'))
.pipe(uglify())
.pipe(gulp.dest('./_includes/assets/'))
);
}
// Concatenate and minify site scripts
function scriptsCSSans() {
return (
gulp
.src(['./_src/cssans/js/**/*.js'])
.pipe(concat('cssans.min.js'))
.pipe(uglify())
.pipe(gulp.dest('./dist/'))
);
}
// Jekyll task
function jekyll() {
return gulp.src('.').pipe(run('bundle exec jekyll build --config _config.yml,_config.dev.yml'));
}
// Jekyll prod
// Useful for testing prod version before deploys
function jekyllProd() {
return gulp.src('.').pipe(run('bundle exec jekyll build'));
}
// Watch files
function watchFiles() {
gulp.watch('./_src/site/sass/**/*', cssSite);
gulp.watch('./_src/cssans/sass/**/*', css);
gulp.watch(['./_src/cssans/js/**/*.js', './_src/site/js/**/*.js'], scriptsSite);
gulp.watch('./_src/cssans/js/**/*', scriptsCSSans);
gulp.watch(
[
'./_includes/**/*.html',
'./_layouts/**/*',
'./_src/site/js/**/*',
'./_src/cssans/js/**/*'
],
gulp.series(jekyll, browserSyncReload)
);
}
const css = gulp.series(cssSite, cssans);
const js = gulp.series(scriptsSite, scriptsCSSans);
const watch = gulp.series(clean, js, jekyll, css, gulp.parallel(watchFiles, browserSync));
const test = gulp.series(clean, js, css, jekyllProd, gulp.parallel(watchFiles, browserSync));
exports.clean = clean;
exports.css = css;
exports.js = js;
exports.test = test;
exports.default = watch;