-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
133 lines (110 loc) · 3.08 KB
/
Copy pathgulpfile.js
File metadata and controls
133 lines (110 loc) · 3.08 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
132
133
'use strict';
// Requirement
// Gulp
var gulp = require('gulp');
// Sass/CSS stuff
var sass = require('gulp-sass');
var prefix = require('gulp-autoprefixer');
var minifycss = require('gulp-minify-css');
// JavaScript
var uglify = require('gulp-uglify');
// Images
var svgmin = require('gulp-svgmin');
var imagemin = require('gulp-imagemin');
// Stats and Things
var size = require('gulp-size');
// Livereload server
var livereload = require('gulp-refresh');
var http = require('http');
var st = require('st');
// Plugin gulp to build blocks in the HTML
var useref = require('gulp-useref');
var filter = require('gulp-filter');
var clean = require('gulp-clean');
// Plugin gulp to zip dist folder
var zip = require('gulp-zip');
var jsfilter = filter('**/*.js');
var cssfilter = filter('**/*.css');
// Gulp task
// compile all your Sass
gulp.task('sass', function (){
gulp.src(['./src/sass/*.scss', '!./src/sass/_variables.scss'])
.pipe(sass({
includePaths: ['./src/sass'],
outputStyle: 'expanded'
}))
.pipe(prefix(
"last 1 version", "> 1%", "ie 8", "ie 7"
))
.pipe(gulp.dest('./src/css'))
.pipe(minifycss())
.pipe(gulp.dest('./dist/css'))
.pipe(livereload());
});
// Uglify JS
gulp.task('uglify', function(){
gulp.src('./src/js/*.js')
.pipe(uglify())
.pipe(gulp.dest('./dist/js'))
.pipe(livereload());
});
// HTML
gulp.task('html', function () {
return gulp.src('src/*.html')
.pipe(useref())
.pipe(gulp.dest('dist'));
});
// Images
gulp.task('svgmin', function() {
gulp.src('./src/img/svg/*.svg')
.pipe(svgmin())
.pipe(gulp.dest('./src/img/svg'))
.pipe(gulp.dest('./dist/img/svg'));
});
gulp.task('imagemin', function () {
gulp.src('./src/img/**/*')
.pipe(imagemin())
.pipe(gulp.dest('./src/img'))
.pipe(gulp.dest('./dist/img'));
});
// Stats and Things
gulp.task('stats', function () {
gulp.src('./dist/**/*')
.pipe(size())
.pipe(gulp.dest('./dist'));
});
// clean dist folder
gulp.task('clean', function(){
return gulp.src('dist', { read: false }).pipe(clean())
});
// archive dist folder
gulp.task('zip', ['default'], function(){
gulp.src('dist/**/*')
.pipe(zip('dist.zip'))
.pipe(gulp.dest('.'));
})
// default task just run />$ gulp
gulp.task('watch', function(){
livereload.listen({port: '8080', host: 'localhost', start: true, index: __dirname + '/dist/index.html' });
// watch me getting Sassy
gulp.watch("./src/sass/**/*.scss", ['sass']).on('change', function(event){
console.log('file changed ' + event.path);
});
// make my JavaScript ugly
gulp.watch('./src/js/**/*.js', ['uglify']).on('change', function(event){
console.log('file changed '+ event.path);
});
// images
gulp.watch('./src/img/**/*', ['imagemin', 'svgmin']).on('change', function(event){
console.log('file changed ' + event.path);
});
// HTML
gulp.watch('./src/*.html', ['html']).on('change', function(event){
console.log('file changed ' + event.path);
});
});
gulp.task('default', ['sass', 'uglify', 'imagemin', 'svgmin', 'html' ], function(done) {
http.createServer(
st({ path: __dirname + '/dist', index: 'index.html', cache: false })
).listen(8080, done);
});