-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
131 lines (120 loc) · 4.36 KB
/
gulpfile.js
File metadata and controls
131 lines (120 loc) · 4.36 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
//Подклячаем модули с package.js
const gulp = require('gulp'); //Модуль Gulp cli
const browserSync = require('browser-sync'); //Для автоматического бновления браузера
const autoprefixer = require('gulp-autoprefixer'); //Подставляет префикси в CSS для поддержки браузеров
const cheerio = require('gulp-cheerio');
const cleanCSS = require('gulp-clean-css'); //Минифицырует CSS
const concat = require('gulp-concat'); //Соидиняет файлы в один файл в заданой последовательности
const replace = require('gulp-replace'); //Замена строки
const svgSprite = require('gulp-svg-sprite'); // Для создания SVG-спрайта
const svgMin = require('gulp-svgmin'); //Минифицырует SVG файлы
const uglify = require('gulp-uglify'); //Минифицырует JS файлы
const watch = require('gulp-watch'); //Отслежует изменения в рабочей директории проэкта
const rimraf = require('rimraf'); //Удаляет папку
const reload = browserSync.reload; //Перезагрузка сервера (Обновление)
const cssFiles = [
'./src/css/main.css',
'./src/css/media.css'
];
const browserslist = [
"last 2 version",
"> 1%",
"IE 10"
];
const path = { //Создаем обьект путей
src: {
fonts: './src/fonts/**/*.*',
img: ['./src/img/**/*.jpg', './src/img/**/*.png'],
svg: './src/img/**/*.svg',
js: './src/js/main.js',
html: './src/index.html',
css: cssFiles
},
build: {
fonts: './build/fonts/',
img: './build/img/',
svg: './build/img/svg/',
js: './build/js/',
html: './build/',
css: './build/css/'
},
watch:{
fonts: './src/fonts/**/*.*',
img: ['./src/img/**/*.jpg', './src/img/**/*.png'],
svg: './src/img/**/*.svg',
js: '.src/js/main.js',
html: './src/index.html',
css: cssFiles
},
del: './build'
};
//Удаляем папку build
gulp.task('del', (cb) => {
return rimraf(path.del, cb)
});
gulp.task('webServer', () => {
browserSync.init({
server: {
baseDir: "./build"
},
host: 'localhost',
port: 1979,
tunel: false
})
});
gulp.task('htmlBuild', () =>{
return gulp.src(path.src.html)
.pipe(gulp.dest(path.build.html))
.pipe(reload({stream: true}));
});
gulp.task('styleBuild', () => {
return gulp.src(path.src.css)
.pipe(concat('style.css'))
.pipe(autoprefixer({
overrideBrowserslist: browserslist,
cascade: false
}
))
.pipe(cleanCSS({level: 2}))
.pipe(gulp.dest(path.build.css))
.pipe(reload({stream: true}));
});
gulp.task('imgBuild', () => {
return gulp.src(path.src.img)
.pipe(gulp.dest(path.build.img))
.pipe(reload({stream: true}));
});
gulp.task('svgBuild', () => {
return gulp.src(path.src.svg)
.pipe(svgMin())
.pipe(svgSprite({
mode: {
stack: {
sprite: "../sprite.svg"
}
}
}
))
.pipe(gulp.dest(path.build.svg))
.pipe(reload({stream: true}));
});
gulp.task('jsBuild', () => {
return gulp.src(path.src.js)
.pipe(gulp.dest(path.build.js))
.pipe(reload({stream: true}));
});
gulp.task('fontsBuild', () => {
return gulp.src(path.src.fonts)
.pipe(gulp.dest(path.build.fonts))
.pipe(reload({stream: true}));
});
gulp.task('watchFiles', () => {
gulp.watch(path.watch.css, gulp.series('styleBuild'));
gulp.watch(path.watch.html, gulp.series('htmlBuild'));
gulp.watch(path.watch.img, gulp.series('imgBuild'));
gulp.watch(path.watch.svg, gulp.series('svgBuild'));
gulp.watch(path.watch.js, gulp.series('jsBuild'));
gulp.watch(path.watch.fonts, gulp.series('fontsBuild'));
});
gulp.task('build', gulp.series('htmlBuild', 'styleBuild', 'imgBuild', 'svgBuild', 'jsBuild', 'fontsBuild'));
gulp.task('default', gulp.parallel('build', 'watchFiles', 'webServer'));