-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
67 lines (59 loc) · 1.6 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
var gulp = require('gulp');
var sass = require('gulp-sass');
var babel = require('gulp-babel');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var cleanCSS = require('gulp-clean-css');
var del = require('del');
var bsync = require('browser-sync').create();
var paths = {
styles: {
src: './src/scss/**/*.{scss,sass,css}',
dest: './dist/css/'
},
scripts: {
src: './src/js/**/*.js',
dest: './dist/js/'
}
};
// Remove previous build
function clean() {
return del(['dist/']);
}
// Convert Sass/SCSS files to CSS, minify them, and move them to dist
function styles() {
return gulp.src(['src/scss/bootstrap.css', paths.styles.src])
.pipe(sass())
.pipe(concat('main.min.css'))
.pipe(cleanCSS())
.pipe(gulp.dest(paths.styles.dest))
.pipe(bsync.stream())
bsync.reload;
}
// Compress .js files to min.js files and move minified files to distribution directory
function scripts() {
return gulp.src(['./src/js/jquery.js', paths.scripts.src], {sourcemaps: true})
.pipe(babel())
.pipe(uglify())
.pipe(concat('main.min.js'))
.pipe(gulp.dest(paths.scripts.dest))
.pipe(bsync.stream())
bsync.reload;
}
// Gulp watcher for realtime changes
function watch() {
bsync.init({
server: './'
})
gulp.watch(paths.scripts.src, scripts);
gulp.watch(paths.styles.src, styles);
gulp.watch('*.html').on('change', bsync.reload);
}
// Generate tasks
exports.clean = clean;
exports.styles = styles;
exports.scripts = scripts;
exports.watch = watch;
var build = gulp.series(gulp.parallel(styles, scripts));
gulp.task('build', build);
gulp.task('default', gulp.series(clean, build, watch));