-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathgulpfile.js
81 lines (66 loc) · 2.11 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
const gulp = require('gulp');
const webpack = require('webpack');
const clean = require('gulp-clean');
const gutil = require('gulp-util');
const ftp = require('vinyl-ftp');
const ghPages = require('gulp-gh-pages-will');
const deploy = require('./deploy.config.json');
const deploy_remote_path = '/public/17zt/viewer';
const webpack_config_demo = require('./webpack.config.example.js');
const babel = require('gulp-babel');
const less = require('gulp-less');
const path = require('path');
// var webpack_config_dist = require('./webpack.config.dist.js');
gulp.task('clean:demo', () => {
return gulp.src('./demo', { read: false })
.pipe(clean());
});
// 编译示例
gulp.task('build:demo', ['clean:demo'], (callback) => {
webpack(webpack_config_demo, () => {
// gulp 异步任务必须明确执行 callback() 否则 gulp 将一直卡住
callback();
});
});
// 部署示例到自己的测试服务器
gulp.task('deploy:demo', ['build:demo'], () => {
deploy.log = gutil.log;
const conn = ftp.create(deploy);
return gulp.src('demo/**')
.pipe(conn.dest(deploy_remote_path));
});
// 部署示例到 gh-pages
gulp.task('deploy:gh-pages', ['build:demo'], () => {
return gulp.src('./demo/**')
.pipe(ghPages());
});
gulp.task('publish:clean', () => {
return gulp.src('./dist', { read: false })
.pipe(clean());
});
// 编译 js 文件
gulp.task('publish:js', ['publish:clean'], () => {
return gulp.src('src/**/*.{js,jsx}')
.pipe(babel({
presets: ['es2015', 'stage-1', 'react'],
}))
.pipe(gulp.dest('dist'));
});
// 编译 less 文件
gulp.task('publish:less', ['publish:clean'], () => {
return gulp.src('src/**/*.less')
.pipe(less({
paths: [path.join(__dirname, 'less', 'includes')],
}))
.pipe(gulp.dest('dist'));
});
// 发布 css 文件
gulp.task('publish:css', ['publish:clean'], () => {
return gulp.src('src/**/*.css')
.pipe(gulp.dest('dist'));
});
// 打包发布 npm
gulp.task('publish', ['publish:clean', 'publish:js', 'publish:css']);
gulp.task('demo', ['deploy:demo']);
gulp.task('gh-pages', ['deploy:gh-pages']);
gulp.task('release', ['publish', 'gh-pages']);