-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathgulpfile.js
More file actions
101 lines (89 loc) · 2.83 KB
/
gulpfile.js
File metadata and controls
101 lines (89 loc) · 2.83 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
"use strict";
// Gulp plugins
var gulp = require("gulp"),
autoprefixer = require("gulp-autoprefixer"),
cleanCSS = require("gulp-clean-css"),
jshint = require('gulp-jshint'),
concat = require("gulp-concat"),
gutil = require("gulp-util"),
rename = require("gulp-rename"),
sass = require("gulp-sass"),
sassLint = require("gulp-sass-lint"),
uglify = require("gulp-uglify");
var DATA_DIR = 'data';
var DATA = {
scripts: DATA_DIR + '/scripts',
styles: DATA_DIR + '/styles'
};
var DIST_DIR = 'dist';
var DIST = {
css: DIST_DIR + '/css',
js: DIST_DIR + '/js',
demoCssName: 'demo-utilities',
outputCssName: 'sidebar-menu',
outputJsName: 'sidebar-menu'
};
var buildStylesheet = function(name, options){
gulp.task(name, function () {
var stream = gulp.src(DATA.styles + options.sourceFileName)
.pipe(sass().on('error', gutil.log))
.pipe(autoprefixer([
'Android >= 4',
'Chrome >= 30',
'Firefox >= 30',
'ie >= 9',
'iOS >= 7',
'Opera >= 12',
'Safari >= 6']))
if (options.isMinified){
return stream
.pipe(cleanCSS({ zindex: false }))
.pipe(rename(options.outputFileName + '.min.css'))
.pipe(gulp.dest(DIST.css));
} else {
return stream
.pipe(rename(options.outputFileName + '.css'))
.pipe(gulp.dest(DIST.css));
}
});
}
function doStyles(task) {
var styleName = task[0] + "_styles";
buildStylesheet(styleName, {
sourceFileName: task[1],
outputFileName: task[2],
isMinified: task[3]
});
return styleName;
}
var styleTasks = [
//["Task Name", "Source file name", "Output file name", "Is the stylesheet minified?"]
["main", "/hub.scss", DIST.outputCssName, true],
["demo", "/demo.scss", DIST.demoCssName, true]
].map(doStyles);
gulp.task("styles", styleTasks, function(cb) {
cb();
});
gulp.task('styles:watch', function () {
gulp.watch(['styles']);
});
gulp.task('scripts', function() {
return gulp.src([
DATA.scripts + '/utilities.js',
DATA.scripts + '/component.js'
])
.pipe(concat(DIST.outputJsName + '.js'))
.pipe(gulp.dest(DIST.js))
.pipe(uglify())
.pipe(rename(DIST.outputJsName + '.min.js'))
.pipe(gulp.dest(DIST.js));
});
gulp.task('scripts:watch', function () {
gulp.watch(['scripts']);
});
gulp.task('js_lint', function() {
return gulp.src(DATA.scripts +'/*.js')
.pipe(jshint())
.pipe(jshint.reporter("default"));
});
gulp.task('default', [ 'styles', 'scripts' ]);