/
gulpfile.js
74 lines (60 loc) · 1.95 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
const gulp = require('gulp');
const sourcemaps = require('gulp-sourcemaps');
const vueify = require("vueify");
const uglify = require('gulp-uglify');
const source = require('vinyl-source-stream');
const buffer = require('vinyl-buffer');
const gutil = require('gulp-util');
const browserify = require('browserify');
const babel = require('gulp-babel');
gulp.task('set-dev-node-env', function() {
return process.env.NODE_ENV = 'development';
});
gulp.task('set-prod-node-env', function() {
return process.env.NODE_ENV = 'production';
});
gulp.task('vueify', ["set-prod-node-env"], function() {
// set up the browserify instance on a task basis
let b = browserify({
entries: './index.js',
debug: false,
transform: ["vueify"],
extensions: [".vue"],
standalone: "VuePlupload"
});
b.external("vue");
return b.bundle()
.pipe(source('vue-plupload.js'))
.pipe(buffer())
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(babel({
presets: ['@babel/preset-env']
}))
// Add transformation tasks to the pipeline here.
.pipe(uglify())
.on('error', gutil.log)
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest("dist"));
});
gulp.task("sample", ["set-dev-node-env"], function() {
// set up the browserify instance on a task basis
let b = browserify({
entries: './index.js',
debug: true,
transform: ["vueify"],
extensions: [".vue"],
standalone: "VuePlupload"
});
b.external("vue");
return b.bundle()
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(gulp.dest("docs"));
});
gulp.task("dev", ["sample"],function() {
let watcher = gulp.watch('./src/*.vue', ['sample']);
watcher.on('change', function(event) {
console.log('File ' + event.path + ' was ' + event.type + ', running tasks...');
});
});
gulp.task("default", ["vueify"]);