/
gulpfile.js
67 lines (55 loc) · 1.42 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
/*eslint-disable no-var, func-names, prefer-arrow-callback, object-shorthand, require-jsdoc, vars-on-top */
var gulp = require('gulp');
var browserify = require('browserify');
var $ = require('gulp-load-plugins')();
var cors = require('cors');
var source = require('vinyl-source-stream');
function bump(type) {
return gulp.src(['./bower.json', './package.json'])
.pipe($.bump({ type: type }))
.pipe(gulp.dest('./'));
}
gulp.task('bump:major', function() {
return bump('major');
});
gulp.task('bump:minor', function() {
return bump('minor');
});
gulp.task('bump:patch', function() {
return bump('patch');
});
gulp.task('build', function() {
process.env.NODE_ENV = 'production';
process.env.BABEL_ENV = 'commonjs';
var bundler;
var stream;
bundler = browserify({
entries: './src/index.js',
standalone: 'ReactInlineSVG'
});
stream = bundler.bundle();
return stream
.pipe(source('react-inlinesvg.js'))
.pipe(gulp.dest('./standalone/'));
});
gulp.task('server', ['server:local', 'server:xdomain']);
gulp.task('server:local', function() {
return $.connect.server({
root: [__dirname],
port: 1337,
livereload: false,
middleware: function() {
return [cors()];
}
});
});
gulp.task('server:xdomain', function() {
return $.connect.server({
root: [__dirname],
port: 1338,
livereload: false,
middleware: function() {
return [cors()];
}
});
});