-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgulpfile.babel.js
102 lines (82 loc) · 2.38 KB
/
gulpfile.babel.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
102
import gulp from 'gulp';
import babel from 'gulp-babel';
import browserify from 'gulp-browserify';
import concat from 'gulp-concat';
import crx from 'gulp-crx-pkg';
import fs from 'fs';
import less from 'gulp-less';
const files = {
html: './src/**/*.html',
less: './src/less/**/*.less',
rawJS: './src/**/*.js',
};
gulp.task('transpile', () =>
gulp.src(files.rawJS)
.pipe(babel())
.pipe(gulp.dest('./build'))
);
gulp.task('browserify', ['transpile'], () =>
gulp.src('./build/app.js')
.pipe(browserify())
.pipe(gulp.dest('./dist'))
);
gulp.task('html', () =>
gulp.src(files.html)
.pipe(gulp.dest('./dist'))
);
gulp.task('less', () =>
gulp.src(files.less)
.pipe(less())
.pipe(concat('core.css'))
.pipe(gulp.dest('./dist'))
);
gulp.task('uikit-css', () =>
gulp.src('./node_modules/uikit/dist/css/*.css')
.pipe(gulp.dest('./dist'))
);
gulp.task('uikit-css-advanced', () =>
gulp.src('./node_modules/uikit/dist/css/components/*.almost-flat.min.css')
.pipe(concat('advanced.css'))
.pipe(gulp.dest('./dist'))
);
gulp.task('widget-css', () =>
gulp.src('./node_modules/dashr-widget-*/dist/widget.css')
.pipe(concat('widgets.css'))
.pipe(gulp.dest('./dist'))
);
gulp.task('uikit-fonts', () =>
gulp.src('./node_modules/uikit/dist/fonts/**/*')
.pipe(gulp.dest('./fonts'))
);
gulp.task('uikit-jquery', () =>
gulp.src('./node_modules/jquery/dist/jquery.js')
.pipe(gulp.dest('./dist'))
);
gulp.task('uikit-js', () =>
gulp.src('./node_modules/uikit/dist/js/uikit.js')
.pipe(gulp.dest('./dist'))
);
gulp.task('uikit', ['uikit-css', 'uikit-css-advanced', 'widget-css', 'uikit-fonts', 'uikit-jquery', 'uikit-js']);
gulp.task('build', ['uikit', 'html', 'browserify', 'less']);
gulp.task('watch', ['build'], () => {
gulp.watch(files.rawJS, ['browserify']);
gulp.watch(files.html, ['html']);
gulp.watch(files.less, ['less']);
});
gulp.task('crx-dist', ['build'], () =>
gulp.src('./dist/**/*')
.pipe(gulp.dest('./crx-dist/dist'))
);
gulp.task('crx-icons', ['build'], () =>
gulp.src('./icons/**/*')
.pipe(gulp.dest('./crx-dist/icons'))
);
gulp.task('crx-manifest', ['build'], () =>
gulp.src('./manifest.json')
.pipe(gulp.dest('./crx-dist'))
);
gulp.task('crx-fonts', ['build'], () =>
gulp.src('./fonts/**/*')
.pipe(gulp.dest('./crx-dist/fonts'))
);
gulp.task('dist', ['crx-dist', 'crx-icons', 'crx-manifest', 'crx-fonts']);