-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
75 lines (64 loc) · 2.13 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
var gulp = require("gulp"),
browserSync = require("browser-sync"),
changed = require("gulp-changed"),
size = require("gulp-size"),
sorting = require("postcss-sorting"),
clean = require("gulp-clean");
gulp.dest(function(file){
return path.join(build_dir, path.dirname(file.path));
});
gulp.task("clean", function () {
return gulp.src('./public', {read: false})
.pipe(clean());
});
gulp.task("html", function() {
return gulp.src(["./src/*.html", "./src/**/*.html"])
.pipe(gulp.dest("public/"));
});
gulp.task("javascript", function() {
return gulp.src(["./src/*.html", "./src/**/*.html"])
.pipe(gulp.dest("public/"));
});
gulp.task("images", function() {
return gulp.src(["./src/**/*.jpg", "./src/**/*.png", "./src/**/*.svg"])
.pipe(gulp.dest("public/"));
});
gulp.task("css", function () {
var postcss = require("gulp-postcss");
//var sourcemaps = require("gulp-sourcemaps");
return gulp.src("src/**/*.css")
//.pipe( sourcemaps.init() )
.pipe( postcss([
sorting({ "sort-order": "alphabetical" }),
require("autoprefixer"),
require("postcss-nested"),
require("precss"),
require('postcss-partial-import')()
]) )
//.pipe( sourcemaps.write(".") )
.pipe( gulp.dest("public/") );
});
gulp.task("js", function() {
return gulp.src(["./src/*.js", "./src/**/*.js"])
.pipe(gulp.dest("public/"));
});
gulp.task("browser-sync", ["html","css","js"], function() {
browserSync({
server: {
baseDir: "./public/",
injectChanges: true,
files: ["./public/**/*"],
}
});
});
gulp.task("watch", function() {
// Watch .html files
gulp.watch("src/*.html", ["html", browserSync.reload]);
gulp.watch("src/**/*.html", ["html", browserSync.reload]);
gulp.watch("src/**/*.css", ["css", browserSync.reload]);
gulp.watch("src/**/*.js", ["js", browserSync.reload]);
gulp.watch("src/**/*.jpg", ["images", browserSync.reload]);
gulp.watch("src/**/*.png", ["images", browserSync.reload]);
gulp.watch("src/**/*.svg", ["images", browserSync.reload]);
});
gulp.task("default", ["html","js","css","images","browser-sync","watch"]);