-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
96 lines (86 loc) · 2.34 KB
/
gulpfile.js
File metadata and controls
96 lines (86 loc) · 2.34 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
"use strict"
// Load plugins
const autoprefixer = require("autoprefixer")
const browsersync = require("browser-sync").create()
const cp = require("child_process")
const cssnano = require("cssnano")
const del = require("del")
const eslint = require("gulp-eslint")
const gulp = require("gulp")
const newer = require("gulp-newer")
const plumber = require("gulp-plumber")
const postcss = require("gulp-postcss")
const rename = require("gulp-rename")
const sass = require("gulp-sass")
const webpack = require("webpack")
const webpackconfig = require("./webpack.config.js")
const webpackstream = require("webpack-stream")
// BrowserSync
function browserSync(done) {
browsersync.init({
proxy: "localhost/nucleoroto.org",
options: {
reloadDelay: 10
},
port: 3000
})
done()
}
// BrowserSync Reload
function browserSyncReload(done) {
browsersync.reload()
done()
}
// Clean assets
function clean() {
return del(["./public/"])
}
// CSS task
function css() {
return gulp
.src("./scss/**/*.scss")
.pipe(plumber())
.pipe(sass({ outputStyle: "expanded" }))
.pipe(gulp.dest("./public/css/"))
.pipe(rename({ suffix: ".min" }))
.pipe(postcss([autoprefixer(), cssnano()]))
.pipe(gulp.dest("./public/css/"))
.pipe(browsersync.stream())
}
// Lint scripts
function scriptsLint() {
return gulp
.src(["./js/**/*", "./gulpfile.js"])
.pipe(plumber())
.pipe(eslint())
.pipe(eslint.format())
.pipe(eslint.failAfterError())
}
// Transpile, concatenate and minify scripts
function scripts() {
return (
gulp
.src(["./js/**/*"])
.pipe(plumber())
.pipe(webpackstream(webpackconfig, webpack))
// folder only, filename is specified in webpack config
.pipe(gulp.dest("./public/js/"))
.pipe(browsersync.stream())
)
}
// Watch files
function watchFiles() {
gulp.watch("./scss/**/*", css)
gulp.watch("./js/**/*", gulp.series(scriptsLint, scripts))
}
// define complex tasks
const js = gulp.series(scriptsLint, scripts)
const build = gulp.series(clean, gulp.parallel(css, js))
const watch = gulp.parallel(watchFiles, build, browserSync)
// export tasks
exports.css = css
exports.js = js
exports.clean = clean
exports.build = build
exports.watch = watch
exports.default = build