-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
101 lines (91 loc) · 2.96 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
// Définition des dépendances dont on a besoin pour exécuter les tâches
var
gulp = require('gulp'),
imagemin = require('gulp-imagemin'),
destclean = require('gulp-dest-clean'),
newer = require('gulp-newer'),
size = require('gulp-size'),
imacss = require('gulp-imacss'),
sass = require('gulp-sass'),
htmlclean = require('gulp-htmlclean'),
preprocess = require('gulp-preprocess'),
pkg = require('./package.json'),
del = require('del');
// Définition de quelques variables générales pour notre gulpfile
var
devBuild = ((process.env.NODE_ENV || 'development').trim().toLowerCase() !== 'production'),
source = 'source/',
dest = 'build/';
// Définition de quelques variables liées à nos tâches (options de tâches)
var
imagesOpts = {
in: source + 'images/*.*',
out: dest + 'images/',
watch: source + 'images/*.*'
},
imageUriOpts = {
in: source + 'images/inline/*.*',
out: source + 'scss/images/',
filename: '_datauri.scss',
namespace: 'img'
},
css = {
in: source + 'scss/main.scss',
watch: [source + 'scss/**/*'],
out: dest + 'css/',
sassOpts: {
outputStyle: 'expanded',
precision: 3,
errLogToConsole: true
}
},
html = {
in: source + '*.html',
watch: [source + '*.html', source + 'template/**/*'],
out: dest,
context: {
devBuild: devBuild,
author: pkg.author,
version: pkg.version
}
};
// Définition des tâches
gulp.task('clean', function () {
del([dest + '*']);
});
gulp.task('images', function () {
return gulp.src(imagesOpts.in)
.pipe(destclean(imagesOpts.out))
.pipe(newer(imagesOpts.out))
.pipe(size({title: 'Images size before compression: ', showFiles: true}))
.pipe(imagemin())
.pipe(size({title: 'Images size after compression: ', showFiles: true}))
.pipe(gulp.dest(imagesOpts.out));
});
gulp.task('imageuri', function () {
return gulp.src(imageUriOpts.in)
.pipe(imagemin())
.pipe(imacss(imageUriOpts.filename, imageUriOpts.namespace))
.pipe(gulp.dest(imageUriOpts.out));
});
gulp.task('sass', function () {
return gulp.src(css.in)
.pipe(sass(css.sassOpts))
.pipe(gulp.dest(css.out));
});
gulp.task('html', function () {
var page = gulp.src(html.in).pipe(preprocess({context: html.context}));
if (!devBuild) {
page = page
.pipe(size({title:'HTML avant minification:'}))
.pipe(htmlclean())
.pipe(size({title:'HTML après minification:'}));
}
return page.pipe(gulp.dest(html.out));
});
// Tâche par défaut exécutée lorsqu’on tape juste *gulp* dans le terminal
gulp.task('default', ['images', 'sass'], function () {
gulp.watch(html.watch, ['html']);
gulp.watch(imagesOpts.watch, ['images']);
gulp.watch(css.watch, ['sass']);
});