forked from schollz/awsm.css
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
116 lines (94 loc) · 2.33 KB
/
gulpfile.js
File metadata and controls
116 lines (94 loc) · 2.33 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
/* requires */
var gulp = require('gulp');
var bs = require('browser-sync');
var $ = require('gulp-load-plugins')({
replaceString: /^gulp(-|\.)|postcss-/,
pattern: ['*'],
rename: {
postcss: "postcss-base" // for difference between gulp-postcss & postcss
}
});
/* paths */
var input = {
pug: ['dev/docs/**/*.pug'],
html: ['dev/docs/**/*.html', '!dev/docs/includes/*.html'] ,
scss: 'dev/scss/**/*.scss',
images: 'dev/docs/images/*'
};
var output = {
dist: 'dist',
main: 'docs',
css: 'docs/css',
images: 'docs/images'
};
var errorHandler = function(title) {
return $.plumber({
errorHandler: $.notify.onError(function(err) {
return {
title: title + ' (' + err.plugin + ')',
message: err.message
};
})
});
};
gulp.task('markup', function() {
return gulp.src(input.pug)
.pipe(errorHandler('Markup'))
.pipe($.filter(['**/!(_)*.pug']))
.pipe($.pug({
pretty: true
}))
.pipe(gulp.dest(output.main))
.pipe(bs.stream());
});
gulp.task('lint', function() {
return gulp.src(input.scss)
.pipe(errorHandler('Linter'))
.pipe($.stylelint({
reporters: [
{ formatter: 'string', console: true }
]
}));
});
gulp.task('styles', function() {
return gulp.src(input.scss)
.pipe(errorHandler('Styles'))
.pipe($.concat('awsm.scss'))
.pipe($.sass())
.pipe($.postcss([
$.autoprefixer({ browsers: [ "> 1%" ] }),
$.discardComments()
]))
.pipe(gulp.dest(output.css))
.pipe(gulp.dest(output.dist))
.pipe($.csso())
.pipe($.rename('awsm.min.css'))
.pipe(gulp.dest(output.css))
.pipe(gulp.dest(output.dist))
.pipe(bs.stream());
});
gulp.task('images', function() {
return gulp.src(input.images)
.pipe(errorHandler('Images'))
.pipe(gulp.dest(output.images))
.pipe(bs.stream());
});
gulp.task('server', function() {
bs.init({
server: output.main,
open: false,
browser: "browser",
reloadOnRestart: true,
notify: false
});
});
gulp.task('watch', function() {
gulp.watch(input.pug, gulp.series('markup'));
gulp.watch(input.scss, gulp.series('lint', 'styles'));
gulp.watch(input.images, gulp.series('images'));
});
gulp.task('clean', function(cb) {
return $.del(output.main);
});
gulp.task('build', gulp.series('markup', 'lint', 'styles', 'images'));
gulp.task('default', gulp.series('build', gulp.parallel('watch', 'server')));