-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
49 lines (43 loc) · 1.47 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
const gulp = require('gulp');
const sass = require('gulp-sass')(require('sass'));
const concat = require('gulp-concat');
const uglify = require('gulp-uglify');
const rename = require('gulp-rename');
// Paths
const paths = {
styles: {
src: 'src/scss/**/*.scss', // Source SCSS files
dest: 'assets/css/' // Destination for compiled CSS
},
scripts: {
src: 'src/js/**/*.js', // Source JavaScript files
dest: 'assets/js/' // Destination for minified JS
}
};
// Compile SCSS into CSS
function styles() {
return gulp.src(paths.styles.src)
.pipe(sass({ outputStyle: 'compressed' }).on('error', sass.logError)) // Compile and minify SCSS
.pipe(rename({ suffix: '.min' })) // Rename to *.min.css
.pipe(gulp.dest(paths.styles.dest));
}
// Minify and Concatenate JS
function scripts() {
return gulp.src(paths.scripts.src)
.pipe(concat('script.js')) // Combine all JS files into one
.pipe(uglify()) // Minify the JavaScript
.pipe(rename({ suffix: '.min' })) // Rename to *.min.js
.pipe(gulp.dest(paths.scripts.dest));
}
// Watch for changes
function watchFiles() {
gulp.watch(paths.styles.src, styles);
gulp.watch(paths.scripts.src, scripts);
}
// Define gulp tasks
const build = gulp.series(gulp.parallel(styles, scripts));
const watch = gulp.series(build, watchFiles);
exports.styles = styles;
exports.scripts = scripts;
exports.watch = watch;
exports.default = build;