-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathgulpfile.js
101 lines (88 loc) · 3.05 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
99
100
101
var gulp = require('gulp'),
sass = require('gulp-sass'),
notify = require('gulp-notify'),
plumber = require('gulp-plumber'),
browserify = require('browserify'),
watchify = require('watchify'),
babelify = require('babelify'),
path = require('path'),
source = require('vinyl-source-stream'),
buffer = require('vinyl-buffer'),
rename = require('gulp-rename'),
uglify = require('gulp-uglify');
//the title and icon that will be used for the notifications
var notifyInfo = {
title: 'Gulp',
icon: path.join(__dirname, 'gulp.png')
};
//error notification settings for plumber
var plumberErrorHandler = { errorHandler: notify.onError({
title: notifyInfo.title,
icon: notifyInfo.icon,
message: "Error: <%= error.message %>"
})
};
var deps = [
'jquery',
'bootstrap',
'lodash',
'react',
'react-dom',
'react-lorem-component'
];
var app_bundler = function() {
return browserify({
entries: ['./app_source/js/lj.js'],
external: deps,
bundleExternal: true,
transform: [[babelify, {presets: ["es2015", "react"]}]],
debug: true, // adds sourcemap
cache: {}, packageCache: {}, fullPaths: true // needed for watchify
});
};
var app_bundle_pipeline = function(bundler) {
return bundler
.bundle() // create new bundle using the cache
.pipe(source('lj.js'))
// .pipe(buffer())
// .pipe(sourcemaps.init({loadMaps: true}))
// .pipe(uglify())
// .pipe(sourcemaps.write('./'))
.pipe(gulp.dest('./learning_journal/static/js/'))
.pipe(notify({title: 'Gulp', icon: notifyInfo.icon, message: 'Built JS'}));
};
var app_minify_pipeline = function(bundler) {
return bundler
.bundle() // create new bundle using the cache
.pipe(source('lj.js'))
.pipe(buffer())
.pipe(uglify())
.pipe(rename('lj.min.js'))
.pipe(gulp.dest('./learning_journal/static/js/'))
.pipe(notify({title: 'Gulp', icon: notifyInfo.icon, message: 'Built Minified JS'}));
};
//scripts
gulp.task('scripts', function() {
return app_bundle_pipeline(app_bundler());
});
gulp.task('minify', function() {
return app_minify_pipeline(app_bundler());
})
//styles
gulp.task('styles', function() {
return gulp.src(['./app_source/sass/*.scss'])
.pipe(plumber(plumberErrorHandler))
.pipe(sass({outputStyle: 'compact'}))
.pipe(gulp.dest('learning_journal/static/css'))
.pipe(notify({title: 'Gulp', icon: notifyInfo.icon, message: 'Built CSS'}));
});
//watch and rebuild
gulp.task('watch', ['minify', 'scripts', 'styles'], function() {
gulp.watch('./app_source/sass/*.scss', ['styles']);
var watcher = watchify(app_bundler());
watcher.on('update', function() {
app_bundle_pipeline(watcher);
app_minify_pipeline(watcher);
}); // when any file updates
});
gulp.task('default', ['minify', 'scripts', 'styles']);