-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
157 lines (142 loc) · 3.76 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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
// plugins
const gulp = require('gulp');
const del = require('del');
const htmlmin = require('gulp-htmlmin');
const minifyCss = require('gulp-clean-css');
const sass = require('gulp-dart-sass');
const plumber = require('gulp-plumber');
const imagemin = require('gulp-imagemin');
const autoprefixer = require('gulp-autoprefixer');
const sourcemaps = require('gulp-sourcemaps');
const babel = require('gulp-babel');
const concat = require('gulp-concat');
const browsersync = require('browser-sync').create();
const distFolder = './dist/';
// variables
const assetsFolder = './src/assets/';
const paths = {
html: {
src: './src/**/*.html',
dest: './dist/',
},
css: {
src: [`${assetsFolder}css/sass.css`, `${assetsFolder}css/*.css`],
dest: './dist/assets/css/',
},
scss: {
src: './src/assets/scss/index.scss',
dest: './src/assets/css/',
},
images: {
src: './src/assets/img/**/*.*',
dest: './dist/assets/img/',
},
font: {
src: './src/assets/fonts/**/*',
dest: './dist/assets/fonts/',
},
js: {
src: './src/assets/js/**/*.js',
dest: './dist/assets/js/',
},
};
function browserSync() {
browsersync.init({
// BrowserSync
server: {
baseDir: distFolder,
},
port: 3000,
});
}
// Permet de supprimer le répertoire distFolder
function clear() {
return del([distFolder, `${assetsFolder}css/sass.css`]);
}
// Tâche permettant de minimifier les fichiers html et de les copier vers dist/
function html() {
return (
gulp
.src(paths.html.src, { since: gulp.lastRun(html) })
.pipe(plumber())
.pipe(htmlmin({ collapseWhitespace: true }))
.pipe(gulp.dest(paths.html.dest))
.pipe(browsersync.stream())
);
}
// Tâche permettant de minimifier les css et de les copier vers dist/assets/css/
function css() {
return (
gulp
.src(paths.css.src)
.pipe(plumber())
.pipe(autoprefixer())
.pipe(minifyCss())
.pipe(concat('style.min.css'))
.pipe(gulp.dest(paths.css.dest))
.pipe(browsersync.stream())
);
}
// Tâche permettant de transpiler et de minimifier les scss et de les copier vers dist/assets/css/
function scss() {
return (
gulp
.src(paths.scss.src)
.pipe(plumber())
.pipe(sass())
.pipe(concat('sass.css'))
.pipe(gulp.dest(paths.scss.dest))
.pipe(browsersync.stream())
);
}
// Tâche permettant de minimifier les images et de les copier vers dist/assets/img/
function images() {
return (
gulp
.src(paths.images.src)
.pipe(plumber())
.pipe(imagemin())
.pipe(gulp.dest(paths.images.dest))
.pipe(browsersync.stream())
);
}
// Tâche permettant de minimifier les polices et de les copier vers dist/assets/fonts/
function font() {
return (
gulp
.src(paths.font.src)
.pipe(plumber())
.pipe(gulp.dest(paths.font.dest))
.pipe(browsersync.stream())
);
}
// Tâche permettant de minimifier les fichiers js et de les copier vers dist/assets/js/
function js() {
return (
gulp
.src(paths.js.src)
.pipe(sourcemaps.init())
.pipe(babel({
presets: ['@babel/preset-env'],
}))
.pipe(concat('all.js'))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest(paths.js.dest))
.pipe(browsersync.stream())
);
}
// Idem watch() avec les images en plus pour le build
function watchFiles() {
gulp.watch(paths.html.src, html);
gulp.watch(paths.scss.src, scss);
gulp.watch(paths.js.src, js);
gulp.watch(paths.css.src, css);
gulp.watch(paths.font.src, font);
gulp.watch(paths.images.src, images);
}
const serie = gulp.series(clear, scss, html, css, js, images, font);
const build = gulp.series(serie, gulp.parallel(watchFiles, browserSync));
// exports
exports.clear = clear;
exports.build = build;
exports.default = build;