-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
gulpfile.js
117 lines (106 loc) · 3.12 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
"use strict";
// Load plugins
const gulp = require("gulp");
const rev = require("gulp-rev");
const sass = require("gulp-sass");
const rename = require("gulp-rename");
const browsersync = require("browser-sync");
const webpack = require("webpack-stream");
const del = require("del");
const postcss = require("gulp-postcss");
const autoprefixer = require("autoprefixer");
function swallowError(error) {
console.log(error.toString());
this.emit("end")
}
// BrowserSync
function browserSync(done) {
browsersync.init({
notify: false,
proxy: "127.0.0.1:5003",
port: 3000
});
done();
}
// BrowserSync reload
function browserSyncReload(done) {
browsersync.reload();
done();
}
// Compile CSS
function css() {
del("app/static/*.css");
return gulp.src("app/static/styles/main.scss")
.pipe(sass({outputStyle: 'compressed'}).on("error", swallowError))
.pipe(postcss([autoprefixer()]))
.pipe(rev())
.pipe(gulp.dest("app/static/"))
.pipe(rev.manifest('app/static/manifest.json', {base: "app/static/", merge: true}))
.pipe(gulp.dest("app/static/"))
.pipe(browsersync.stream());
}
// Compile JS
function js() {
del("app/static/*.js");
return gulp
.src("app/static/scripts/main.js")
.pipe(webpack({
entry: {
main: "./app/static/scripts/main.js",
admin: "./app/static/scripts/admin.js"
},
output: {filename: "[name].js"},
mode: "production"
}))
.on("error", swallowError)
.pipe(rev())
.pipe(gulp.dest("app/static/"))
.pipe(rev.manifest('app/static/manifest.json', {base: "app/static/", merge: true}))
.pipe(gulp.dest("app/static/"))
.pipe(browsersync.stream());
}
function clean() {
return del("dist");
}
function build() {
gulp
.src("prod.env")
.pipe(rename(".env"))
.pipe(gulp.dest("dist"));
gulp
.src(["*.py"])
.pipe(gulp.dest("dist"));
gulp
.src(["requirements.txt"])
.pipe(gulp.dest("dist"));
gulp
.src(".deploy-config/*", { dot: true })
.pipe(gulp.dest("dist/"));
gulp
.src(["app/**/*.py", "app/**/*.html", "app/**/*.txt"])
.pipe(gulp.dest("dist/app"));
gulp
.src(["app/static/*.css", "app/static/*.js", "app/static/*.json"])
.pipe(gulp.dest("dist/app/static"));
gulp
.src(["app/static/docs/**/*.pdf"])
.pipe(gulp.dest("dist/app/static/docs"));
gulp
.src(["app/static/vendor/**/*"])
.pipe(gulp.dest("dist/app/static/vendor"));
return gulp
.src(["app/static/img/**/*.*"])
.pipe(gulp.dest("dist/app/static/img/"));
}
// Watch files
function watchFiles() {
gulp.watch("app/static/styles/**/*", css);
gulp.watch("app/static/scripts/**/*", js);
gulp.watch("./app/templates/**/*", gulp.series(browserSyncReload));
}
const dist = gulp.series(css, js, clean, build);
const compile = gulp.series(css, js);
const watch = gulp.parallel(watchFiles, browserSync);
exports.build = dist;
exports.compile = compile;
exports.default = watch;