-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
127 lines (115 loc) · 3.03 KB
/
gulpfile.js
File metadata and controls
127 lines (115 loc) · 3.03 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
/*globals require*/
'use strict';
var gulp = require('gulp-help')(require('gulp'));
// Plugins.
var gutil = require('gulp-util');
var jshint = require('gulp-jshint');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');
var sass = require('gulp-sass');
var cleanCSS = require('gulp-clean-css');
var concat = require('gulp-concat');
var gulpStylelint = require('gulp-stylelint');
var argv = require('yargs').argv;
// We only want to process our own non-processed JavaScript files.
// var jsPath = './scripts/ddbasic.!(*.min).js';
var jsPath = ['./scripts/**/*.js', '!./scripts/contrib/*', '!./scripts/min/**/*.js'];
var sassPath = ['./sass/**/*.scss', '!./sass/contrib/**'];
gulp.task('jshint', 'Run Javascript through JSHint',
function() {
return gulp.src(jsPath)
.pipe(jshint())
.pipe(jshint.reporter('jshint-stylish'));
}
);
gulp.task('uglify', 'Minify JavaScript using Uglify',
function() {
gulp.src(jsPath)
.pipe(uglify({
// Preserve the $ variable name.
mangle: { except: ['$'] }
}).on('error', gutil.log))
.pipe(gulp.dest('./scripts/min'));
}
);
/**
* Usage:
* gulp validate-sass [--dir=foldername]
*
* Check that all .scss files are style compliant
*
* Arguments:
*
* foldername - Optional foldername to check just a single folder
*
*/
gulp.task('validate-sass', 'Validate the SCSS', function () {
var testPath = argv.dir ? ['./sass/' + argv.dir + "/*.scss"] : sassPath;
return gulp
.src(testPath)
.pipe(gulpStylelint({
syntax: 'scss',
reporters: [
{formatter: 'string', console: true}
]
}));
});
/**
* Usage:
* gulp sass
*
* Precompile all sass files into css files in the sass_css folder
*
*/
gulp.task('sass', 'Process SCSS into individual css files using libsass',
function () {
gulp.src(sassPath)
.pipe(sass({outputStyle: 'nested'})
.on('error', sass.logError))
// Save verbose output for testing purposes.
.pipe(gulp.dest('./sass_css_verbose_output'))
// Minify the css and save it.
.pipe(cleanCSS())
.pipe(gulp.dest('./sass_css'));
}
);
/**
* Usage:
* gulp kss
*
* Create the KSS micro site in the stylesheets folder.
* See ./sass/homepage.md
*
* To update the kss css files call gulp ksssass.
*
*/
gulp.task('kss', 'Process SCSS using KSS / kss-node',
function () {
// Use kss-node and not gulp-kss
var kss = require('kss');
var styleGuide = {
source: './sass',
css: '../sass_css/bundle.css'
};
// Create the bundle.css
gulp.src('./sass_css/**/*.css')
.pipe(cleanCSS())
.pipe(concat('bundle.css'))
.pipe(gulp.dest('./sass_css'));
return kss(styleGuide);
}
);
/**
* Usage:
* gulp watch
*
* Watch js and sass files for changes and gulp accordingly
*
*/
gulp.task('watch', 'Watch and process JS and SCSS files', ['uglify', 'sass'],
function() {
gulp.watch(jsPath, ['jshint', 'uglify']);
gulp.watch(sassPath, ['validate-sass', 'sass']);
}
);
gulp.task('default', ['help']);