-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathgulpfile.babel.js
More file actions
66 lines (57 loc) · 1.48 KB
/
gulpfile.babel.js
File metadata and controls
66 lines (57 loc) · 1.48 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
const gulp = require("gulp");
const clean = require('gulp-clean');
const ts = require("gulp-typescript");
const uglify = require("gulp-uglify");
const rename = require('gulp-rename');
const sass = require('gulp-sass')(require('sass'));
const webserver = require("gulp-webserver");
const paths = {
dist : ["dist"],
src : ["src"],
}
gulp.task("clean", function () {
return gulp.src([`${paths.dist}/js`, `${paths.dist}/css`], {allowEmpty:true})
.pipe(clean());
});
// babel
gulp.task("babel", function () {
return gulp.src("src/*.ts")
.pipe(ts({
noImplicitAny: true,
// module: "commonjs"
module: "es6",
target: "es5"
}))
.pipe(uglify()) // minify
.pipe(rename(function (p) {
p.basename += '.min';
}))
.pipe(gulp.dest(`${paths.dist}/js`));
});
gulp.task("sass", function(){
return gulp.src(`${paths.src}/*.scss`)
.pipe(sass())
.pipe(rename(function (p) {
p.basename += '.min';
}))
.pipe(gulp.dest(`${paths.dist}/css`));
})
// webserver
gulp.task("webserver", function(){
gulp.src(paths.dist)
.pipe(
webserver({
port: 5000,
livereload: true,
open: true,
})
);
});
gulp.task("builds", gulp.series("clean", "babel", "sass"));
// watch
gulp.task("watch", function(){
gulp.watch(`${paths.src}/*`, gulp.series("builds"));
});
gulp.task("dev", gulp.parallel("builds", "webserver", "watch"));
gulp.task("build", gulp.parallel("builds"));
gulp.task("default", gulp.parallel("builds"));