-
Notifications
You must be signed in to change notification settings - Fork 190
/
gulpfile.js
103 lines (90 loc) · 2.49 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
'use strict';
const gulp = require('gulp');
const del = require('del');
const sass = require('gulp-sass');
const rename = require ('gulp-rename');
const hb = require('gulp-hb');
const layouts = require('handlebars-layouts');
const sourcemaps = require("gulp-sourcemaps");
const srcPaths = {
scripts: ['./src/js/**/*'],
fonts: ['./src/fonts/**/*'],
images: ['./src/img/**/*'],
styles: ['./src/sass/*.scss'],
cssEntries: ['./src/sass/application.scss'],
static: ['./src/demo/**/*'],
templates: [
'src/*.hbs',
'src/pages/**/*.hbs'
],
partials: ['./src/partials/*.hbs'],
helpers: [
'./node_modules/handlebars-layouts/index.js',
'./src/helpers/index.js'
]
};
hb.handlebars.registerHelper(layouts(hb.handlebars));
async function clean(cb) {
return del(["dist/*"]);
cb();
}
// Copy demo, img, js, fonts folders from src to dist
async function copy(cb) {
return gulp
.src([...srcPaths.static, ...srcPaths.images, ...srcPaths.fonts], {
base: "./src"
})
.pipe(gulp.dest("dist"));
cb();
}
async function copyJS(cb) {
return gulp.src(srcPaths.scripts).pipe(gulp.dest("dist/js"));
cb();
}
// Handle handlebars
function hbs() {
// gulp.task("hbs", function() {
return gulp
.src(srcPaths.templates)
.pipe(
hb({
partials: srcPaths.partials,
helpers: srcPaths.helpers
})
)
.pipe(rename({ extname: ".html" }))
.pipe(gulp.dest("dist"));
}
// Handle sass
function styles() {
return gulp
.src(srcPaths.styles)
.pipe(sourcemaps.init())
.pipe(
sass({
precision: 10,
outputStyle: "compressed"
}).on("error", sass.logError)
)
.pipe(rename({ suffix: ".min" }))
.pipe(sourcemaps.write("./maps"))
.pipe(gulp.dest("./dist/css"));
}
// Development
exports.watch = function watch() {
gulp.watch(srcPaths.scripts, gulp.series(copyJS));
gulp.watch(srcPaths.styles, gulp.series(styles));
gulp.watch([...srcPaths.templates, ...srcPaths.partials], gulp.series(hbs));
gulp.watch(
[...srcPaths.static, ...srcPaths.images, ...srcPaths.fonts],
gulp.series(copy)
);
};
gulp.task("build", gulp.parallel(hbs, styles, copy, copyJS));
// Build Task
function build(cb) {
return gulp.parallel(clean, "build");
cb();
}
// Default Task
gulp.task("default", gulp.parallel(clean, "build"));