-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
79 lines (70 loc) · 3.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
'use strict';
var gulp = require('gulp'); // Base gulp package
var babelify = require('babelify'); // Used to convert ES6 & JSX to ES5
var browserify = require('browserify'); // Providers "require" support, CommonJS
var notify = require('gulp-notify'); // Provides notification to both the console and Growel
var rename = require('gulp-rename'); // Rename sources
var sourcemaps = require('gulp-sourcemaps'); // Provide external sourcemap files
var livereload = require('gulp-livereload'); // Livereload support for the browser
var gutil = require('gulp-util'); // Provides gulp utilities, including logging and beep
var chalk = require('chalk'); // Allows for coloring for logging
var source = require('vinyl-source-stream'); // Vinyl stream support
var buffer = require('vinyl-buffer'); // Vinyl stream support
var watchify = require('watchify'); // Watchify for source changes
var merge = require('utils-merge'); // Object merge tool
var duration = require('gulp-duration'); // Time aspects of your gulp process
// Configuration for Gulp
var config = {
js: {
src: './public/js/main.js',
watch: './public/js/*',
outputDir: './',
outputFile: '/public/js/bundle.js',
},
};
// Error reporting function
function mapError(err) {
if (err.fileName) {
// Regular error
gutil.log(chalk.red(err.name)
+ ': ' + chalk.yellow(err.fileName.replace(__dirname + '/src/js/', ''))
+ ': ' + 'Line ' + chalk.magenta(err.lineNumber)
+ ' & ' + 'Column ' + chalk.magenta(err.columnNumber || err.column)
+ ': ' + chalk.blue(err.description));
} else {
// Browserify error..
gutil.log(chalk.red(err.name)
+ ': '
+ chalk.yellow(err.message));
}
}
// Completes the final file outputs
function bundle(bundler) {
var bundleTimer = duration('Javascript bundle time');
bundler
.bundle()
.on('error', mapError) // Map error reporting
.pipe(source('main.js')) // Set source name
.pipe(buffer()) // Convert to gulp pipeline
.pipe(rename(config.js.outputFile)) // Rename the output file
.pipe(sourcemaps.init({loadMaps: true})) // Extract the inline sourcemaps
.pipe(sourcemaps.write('./map')) // Set folder for sourcemaps to output to
.pipe(gulp.dest(config.js.outputDir)) // Set the output folder
.pipe(notify({
message: 'Generated file: <%= file.relative %>',
})) // Output the file being created
.pipe(bundleTimer) // Output time timing of the file creation
.pipe(livereload()); // Reload the view in the browser
}
// Gulp task for build
gulp.task('default', function() {
livereload.listen(); // Start livereload server
var args = merge(watchify.args, { debug: true }); // Merge in default watchify args with browserify arguments
var bundler = browserify(config.js.src, args) // Browserify
.plugin(watchify, {ignoreWatch: ['**/node_modules/**', '**/bower_components/**']}) // Watchify to watch source file changes
.transform(babelify, {presets: ['es2015', 'react']}); // Babel tranforms
bundle(bundler); // Run the bundle the first time (required for Watchify to kick in)
bundler.on('update', function() {
bundle(bundler); // Re-run bundle on source updates
});
});