-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgulpfile.js
86 lines (75 loc) · 2.29 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
/* Basic gulp concat and minify didesweb.com */
const { src, dest, watch, series, parallel } = require('gulp');
const concat = require('gulp-concat');
const uglify = require('gulp-uglify');
const postcss = require('gulp-postcss');
const autoprefixer = require('autoprefixer');
const cssnano = require('cssnano');
const sourcemaps = require('gulp-sourcemaps');
const cleanCSS = require('gulp-clean-css');
let replace = require('gulp-replace');
// File paths
const files = {
cssPath: 'src/css/*.css',
jsPath: 'src/js/**/*.js',
//jsPathUI: 'src/js/Ui/*.js'
}
// JS task: concatenates and uglifies JS files to app.js
function jsTask(){
return src([
'node_modules/jquery/dist/jquery.min.js',
'node_modules/@fortawesome/fontawesome-free/js/all.js',
'node_modules/bootstrap/dist/js/bootstrap.min.js',
'src/js/Utils/*',
'src/js/Ui/*.js',
'src/js/Analyser.js',
'src/js/Track.js',
'src/js/WaveformMarker.js',
'src/js/Player.js',
'src/js/index.js'
],
{base:'node_modules'})
.pipe(concat('app.js'))
//.pipe(uglify())
.pipe(dest('dist')
);
}
// Sass task: compiles the style.scss file into style.css
function cssTask(){
return src([
'node_modules/bootstrap/dist/css/bootstrap.css',
'node_modules/@fortawesome/fontawesome-free/css/fontawesome.css',
files.cssPath
],
{base:'node_modules'})
.pipe(concat('app.css'))
.pipe(sourcemaps.init()) // initialize sourcemaps first
.pipe(postcss([ autoprefixer(), cssnano() ])) // PostCSS plugins
.pipe(cleanCSS({compatibility: 'ie8'}))
.pipe(sourcemaps.write('.')) // write sourcemaps file in current directory
.pipe(dest('dist')
); // put final CSS in dist folder
}
// Cachebust
let cbString = new Date().getTime();
function cacheBustTask(){
return src(['index.html'])
.pipe(replace(/cb=\d+/g, 'cb=' + cbString))
.pipe(dest('.'));
}
// Watch task: watch SCSS and JS files for changes
// If any change, run scss and js tasks simultaneously
function watchTask(){
watch([files.cssPath,files.jsPath],
series(
parallel(cssTask, jsTask),
cacheBustTask
)
);
}
// Run: "yarn run gulp"
exports.default = series(
parallel(cssTask, jsTask),
cacheBustTask,
watchTask
);