-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
102 lines (91 loc) · 2.23 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
var gulp = require("gulp"),
autoprefixer = require("gulp-autoprefixer"),
browserSync = require("browser-sync").create(),
reload = browserSync.reload,
sass = require("gulp-sass"),
sourcemaps = require("gulp-sourcemaps"),
concat = require("gulp-concat"),
imagemin = require("gulp-imagemin"),
changed = require("gulp-changed"),
uglify = require("gulp-uglify"),
lineec = require("gulp-line-ending-corrector");
//Html
var htmlSrc = "src/**/*.html";
var htmlDist = "dist/";
var htmlWatch = "dist/**/*.html";
//style
var styleSrc = "src/sass/style.scss";
var styleDist = "dist/css/";
var styleWatch = "src/sass/**/*.scss";
//Js
var jsSrc = ["node_modules/jquery/dist/jquery.min.js", "src/js/**/*.js"];
var jsDist = "dist/js/";
//Image
var imgSrc = "src/img/*";
var imgDist = "dist/img/";
//Browser Sync
function watch() {
browserSync.init({
server: {
baseDir: "dist/"
}
});
gulp.watch(htmlSrc, html);
gulp.watch(styleWatch, style);
gulp.watch(jsSrc, javascript);
gulp.watch(imgSrc, imgmin);
gulp
.watch([htmlWatch, jsDist + "bundle.js", styleDist + "style.css"])
.on("change", browserSync.reload);
}
//Html
function html() {
return gulp.src(htmlSrc).pipe(gulp.dest(htmlDist));
}
//Compile Sass
function style() {
return gulp
.src(styleSrc)
.pipe(sourcemaps.init({ loadMaps: true }))
.pipe(
sass({
outputStyle: "compressed"
}).on("error", sass.logError)
)
.pipe(autoprefixer("last 2 versions"))
.pipe(sourcemaps.write())
.pipe(lineec())
.pipe(gulp.dest(styleDist));
}
//Js
function javascript() {
return gulp
.src(jsSrc)
.pipe(concat("bundle.js"))
.pipe(uglify())
.pipe(lineec())
.pipe(gulp.dest(jsDist));
}
//Image
function imgmin() {
return gulp
.src(imgSrc)
.pipe(changed(imgDist))
.pipe(
imagemin([
imagemin.gifsicle({ interlaced: true }),
imagemin.jpegtran({ progressive: true }),
imagemin.optipng({ optimizationLevel: 5 })
])
)
.pipe(gulp.dest(imgDist));
}
//Export function
exports.html = html;
exports.style = style;
exports.javascript = javascript;
exports.watch = watch;
exports.imgmin = imgmin;
//Deafault Task
var build = gulp.parallel(watch);
gulp.task("default", build);