forked from nats-io/nats-site
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulpfile.js
127 lines (113 loc) · 3.88 KB
/
gulpfile.js
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
var gulp = require('gulp'),
debug = require('gulp-debug'),
notify = require('gulp-notify'),
concat = require('gulp-concat'),
rename = require('gulp-rename'),
watch = require('gulp-watch'),
less = require('gulp-less'),
uglify = require('gulp-uglify'),
minifyCSS = require('gulp-minify-css'),
gm = require('gulp-gm'),
imageResize = require('gulp-image-resize'),
gulpif = require('gulp-if'),
autoprefixer = require('gulp-autoprefixer'),
sourcemaps = require('gulp-sourcemaps'),
clean = require('gulp-clean'),
shell = require('gulp-shell'),
runSequence = require('run-sequence');
// LESS
gulp.task('less', function() {
return gulp.src('src/less/styles.less')
.pipe(less())
.pipe(sourcemaps.init())
.pipe(autoprefixer())
//.pipe(minifyCSS())
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('static/css'))
.pipe(notify({ message: 'Compiling LESS'}));
});
// Javascript
gulp.task('js', function() {
return gulp.src(['src/js/moment.js', 'src/js/**/*.js'])
.pipe(concat('index.js'))
.pipe(uglify())
.pipe(gulp.dest('static/js'))
.pipe(notify({ message: 'Compiling JavaScript'}));
});
// Images
gulp.task('img', function() {
return gulp.src('src/img/**/*')
.pipe(gulp.dest('static/img'))
.pipe(notify({ message: 'Copying image'}));
});
// Fonts
gulp.task('font', function() {
return gulp.src('src/fonts/**/*')
.pipe(gulp.dest('static/fonts'))
.pipe(notify({ message: 'Copying font'}));
});
// Resize User Logos
gulp.task('userLogos', function() {
return gulp.src('src/user_logos/**/*')
.pipe(gm(function (gmfile) {
return gmfile.resize(150, 100);
}))
.pipe(gulp.dest('static/img/user_logos'))
.pipe(notify({ message: 'Resizing user logo image'}));
});
// Resize Partner Logos
gulp.task('partnerLogos', function() {
return gulp.src('src/partner_logos/**/*')
.pipe(gm(function (gmfile) {
return gmfile.resize(250, 150);
}))
.pipe(gulp.dest('static/img/partner_logos'))
.pipe(notify({ message: 'Resizing partner logo'}));
});
// Resize Documentaiton Images
gulp.task('docsImages', function() {
return gulp.src('src/documentation/**/*.{png,jpg,jpeg}')
.pipe(gulp.dest('static/img/documentation'))
.pipe(notify({ message: 'Copying documentation image'}));
});
// Resize Blog Images
gulp.task('blogImages', function() {
return gulp.src('src/blog/**/*.{png,jpg,jpeg}')
.pipe(imageResize({
width : 900
}))
.pipe(gulp.dest('static/img/blog'))
.pipe(notify({ message: 'Resizing blog image'}));
});
// Will have to improve this later on
gulp.task('blogImagesGifs', function() {
return gulp.src('src/blog/**/*.gif')
.pipe(gulp.dest('static/img/blog'))
.pipe(notify({ message: 'Copying gif blog image'}));
});
// Clean
gulp.task('clean', function() {
return gulp.src('public')
.pipe(clean())
.pipe(notify({ message: 'Removing old build'}));
});
// HUGO
gulp.task('hugo', shell.task('hugo'))
// Watch
gulp.task('watch', function() {
gulp.watch('src/less/**/*.less', [ 'less' ]);
gulp.watch('src/js/**/*.js', [ 'js' ]);
gulp.watch('src/img/**/*', [ 'img' ]);
gulp.watch('src/font/**/*', [ 'font' ]);
gulp.watch('src/user_logos/**/*', [ 'userLogos' ]);
gulp.watch('src/partner_logos/**/*', [ 'partnerLogos' ]);
gulp.watch('src/company_logos/**/*', [ 'companyLogos' ]);
gulp.watch('src/blog/**/*', [ 'blogImages' ]);
gulp.watch('src/blog/**/*', [ 'blogImagesGifs' ]);
});
// Default Task
gulp.task('default', [ 'less', 'js', 'img', 'font', 'docsImages', 'userLogos', 'partnerLogos', 'blogImages', 'blogImagesGifs', 'watch' ]);
// Build for Production
gulp.task('build', function (callback) {
runSequence( 'clean', [ 'less', 'js', 'img', 'font', 'docsImages', 'userLogos', 'partnerLogos', 'blogImages', 'blogImagesGifs' ], 'hugo', callback);
});