-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgulpfile.js
85 lines (72 loc) · 2.9 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
// -----------------------------------------------------------------------------
// Dependencies
// -----------------------------------------------------------------------------
var gulp = require('gulp');
var sass = require('gulp-sass');
var autoprefixer = require('gulp-autoprefixer');
var browserify = require('browserify');
var watchify = require('watchify');
var source = require('vinyl-source-stream');
var notify = require('gulp-notify');
var babelify = require('babelify');
var streamify = require('gulp-streamify');
var rename = require("gulp-rename");
// -----------------------------------------------------------------------------
// Configuration
// -----------------------------------------------------------------------------
var userPath = './user/themes/<%= siteSlug %>/';
var sassInput = userPath + 'scss/**/*.scss';
var sassOutput = userPath + 'css';
var sassOptions = { outputStyle: 'compressed' };
var autoprefixerOptions = { browsers: ['last 2 versions', '> 5%', 'Firefox ESR'] };
var javascriptMainFile = userPath + 'js/src/application.js';
var javascriptInput = userPath + 'js/src/**/*.js';
var javascriptOutput = 'application.min.js';
var output = userPath + 'js/dist';
// -----------------------------------------------------------------------------
// Browserify
// -----------------------------------------------------------------------------
gulp.task('browserify', function () {
watchify(browserify({
entries: [javascriptMainFile],
debug: true
}))
.transform(babelify, {presets: ['es2015', 'stage-0']})
.bundle()
.on('error', function(err) {
console.error(err.message);
})
.pipe(source(javascriptOutput))
.pipe(gulp.dest(output))
.pipe(notify('Built source!'));
});
// -----------------------------------------------------------------------------
// Sass compilation
// -----------------------------------------------------------------------------
gulp.task('sass', function () {
return gulp
.src(sassInput)
.pipe(sass(sassOptions).on('error', sass.logError))
.pipe(autoprefixer(autoprefixerOptions))
.pipe(rename('application.min.css'))
.pipe(gulp.dest(sassOutput));
});
// -----------------------------------------------------------------------------
// Watch
// -----------------------------------------------------------------------------
gulp.task('watch', function() {
gulp.task('compile')();
var jsWatcher = gulp.watch(javascriptInput);
jsWatcher.on('all', function(event, path, stats) {
gulp.task('browserify')();
});
var cssWatcher = gulp.watch(sassInput);
cssWatcher.on('all', function(event, path, stats) {
gulp.task('sass')();
});
});
// -----------------------------------------------------------------------------
// Default task
// -----------------------------------------------------------------------------
gulp.task('compile', gulp.parallel('sass', 'browserify'));
gulp.task('default', gulp.parallel('watch'));