-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathgulpfile.js
More file actions
131 lines (114 loc) · 3.54 KB
/
gulpfile.js
File metadata and controls
131 lines (114 loc) · 3.54 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
/*
REQUIRED STUFF
==============
*/
var changed = require('gulp-changed');
var gulp = require('gulp');
var sass = require('gulp-sass');
var notify = require('gulp-notify');
var prefix = require('gulp-autoprefixer');
var minifycss = require('gulp-clean-css');
var uglify = require('gulp-uglify');
var cache = require('gulp-cache');
var concat = require('gulp-concat');
var util = require('gulp-util');
var header = require('gulp-header');
var pixrem = require('gulp-pixrem');
var exec = require('child_process').exec;
/*
FILE PATHS
==========
*/
var sassSrc = '*.{sass,scss}';
/*
ERROR HANDLING
==============
*/
var handleError = function(task) {
return function(err) {
notify.onError({
message: task + ' failed, check the logs..'
})(err);
util.log(util.colors.bgRed(task + ' error:'), util.colors.red(err));
};
};
/*
STYLES
======
*/
gulp.task('styles', function() {
gulp.src('theme.scss')
.pipe(sass({
compass: false,
bundleExec: true,
sourcemap: false,
style: 'compressed',
debugInfo: true,
lineNumbers: true,
errLogToConsole: true,
includePaths: [
'node_modules/',
// 'bower_components/',
// require('node-bourbon').includePaths
],
}))
.on('error', handleError('styles'))
.pipe(prefix('last 3 version', 'safari 5', 'ie 9', 'opera 12.1', 'ios 6', 'android 4')) // Adds browser prefixes (eg. -webkit, -moz, etc.)
.pipe(pixrem())
.pipe(minifycss({
advanced: true,
keepBreaks: false,
specialComments: 0,
mediaMerging: true,
sourceMap: true,
debug: true
}, function(details) {
console.log('[clean-css] Original size: ' + details.stats.originalSize + ' bytes');
console.log('[clean-css] Minified size: ' + details.stats.minifiedSize + ' bytes');
console.log('[clean-css] Time spent on minification: ' + details.stats.timeSpent + ' ms');
console.log('[clean-css] Compression efficiency: ' + details.stats.efficiency * 100 + ' %');
}))
.pipe(gulp.dest('./'))
gulp.src('theme-dark.scss')
.pipe(sass({
compass: false,
bundleExec: true,
sourcemap: false,
style: 'compressed',
debugInfo: true,
lineNumbers: true,
errLogToConsole: true,
includePaths: [
'node_modules/',
// 'bower_components/',
// require('node-bourbon').includePaths
],
}))
.on('error', handleError('styles'))
.pipe(prefix('last 3 version', 'safari 5', 'ie 9', 'opera 12.1', 'ios 6', 'android 4')) // Adds browser prefixes (eg. -webkit, -moz, etc.)
.pipe(pixrem())
.pipe(minifycss({
advanced: true,
keepBreaks: false,
specialComments: 0,
mediaMerging: true,
sourceMap: true,
debug: true
}, function(details) {
console.log('[clean-css] Original size: ' + details.stats.originalSize + ' bytes');
console.log('[clean-css] Minified size: ' + details.stats.minifiedSize + ' bytes');
console.log('[clean-css] Time spent on minification: ' + details.stats.timeSpent + ' ms');
console.log('[clean-css] Compression efficiency: ' + details.stats.efficiency * 100 + ' %');
}))
.pipe(gulp.dest('./'))
});
/*
TASKS
=====
*/
gulp.task('watch', function() {
gulp.watch(sassSrc, ['styles']);
});
gulp.task('default', function() {
gulp.watch(sassSrc, ['styles']);
});