-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
98 lines (80 loc) · 3.16 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
const path = require('path');
// Config
// -------------------------------------------------------------------------------
const env = require('gulp-environment');
process.env.NODE_ENV = env.current.name;
let serverPath;
const conf = (() => {
const _conf = require('./build-config');
serverPath = _conf.base.serverPath;
templatePath = _conf.base.buildTemplatePath;
buildPath = _conf.base.buildPath;
return require('deepmerge').all([{}, _conf.base || {}, _conf[process.env.NODE_ENV] || {}]);
})();
conf.distPath = path.resolve(__dirname, conf.distPath).replace(/\\/g, '/');
// Modules
// -------------------------------------------------------------------------------
const { parallel, series, watch } = require('gulp');
const del = require('del');
const colors = require('ansi-colors');
const browserSync = require('browser-sync').create();
colors.enabled = require('color-support').hasBasic;
// Utilities
// -------------------------------------------------------------------------------
function srcGlob(...src) {
return src.concat(conf.exclude.map(d => `!${d}/**/*`));
}
// Tasks
// -------------------------------------------------------------------------------
const buildTasks = require('./tasks/build')(conf, srcGlob);
const prodTasks = require('./tasks/prod')(conf);
// Clean build directory
// -------------------------------------------------------------------------------
const cleanTask = function () {
return del([conf.distPath, buildPath], {
force: true
});
};
// Watch
// -------------------------------------------------------------------------------
const watchTask = function () {
watch(srcGlob('**/*.scss', '!fonts/**/*.scss'), buildTasks.css);
watch(srcGlob('fonts/**/*.scss'), parallel(buildTasks.css, buildTasks.fonts));
watch(srcGlob('**/*.@(js|es6)', '!*.js'), buildTasks.js);
// watch(srcGlob('**/*.png', '**/*.gif', '**/*.jpg', '**/*.jpeg', '**/*.svg', '**/*.swf'), copyTasks.copyAssets)
};
// Serve
// -------------------------------------------------------------------------------
const serveTasks = function () {
browserSync.init({
// ? You can change server path variable from build-config.js file
server: serverPath
});
watch([
// ? You can change add/remove files/folders watch paths in below array
'html/**/*.html',
'html-starter/**/*.html',
'assets/vendor/css/*.css',
'assets/vendor/css/rtl/*.css',
'assets/css/*.css',
'assets/js/*.js'
]).on('change', browserSync.reload);
};
const serveTask = parallel([serveTasks, watchTask]);
// Build (Dev & Prod)
// -------------------------------------------------------------------------------
const buildTask = conf.cleanDist
? series(cleanTask, env.current.name === 'production' ? [buildTasks.all, prodTasks.all] : buildTasks.all)
: series(env.current.name === 'production' ? [buildTasks.all, prodTasks.all] : buildTasks.all);
// Exports
// -------------------------------------------------------------------------------
module.exports = {
default: buildTask,
build: buildTask,
'build:js': buildTasks.js,
'build:css': buildTasks.css,
'build:fonts': buildTasks.fonts,
'build:copy': parallel([buildTasks.copy]),
watch: watchTask,
serve: serveTask
};