-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.babel.js
101 lines (86 loc) · 2.74 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
import gulp from 'gulp';
import webpack from 'webpack';
import rimraf from 'rimraf';
import loadPlugins from 'gulp-load-plugins';
const plugins = loadPlugins();
import sass from 'gulp-sass';
import popupWebpackConfig from './popup/webpack.config';
import contentWebpackConfig from './content/webpack.config';
// Compile sass to css for dev.
gulp.task('sass:dev', ['clean'], () => {
return gulp.src('./sass/*.scss')
// Initializes sourcemaps.
.pipe(plugins.sourcemaps.init())
.pipe(sass.sync().on('error', sass.logError))
.pipe(plugins.autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
// Writes sourcemaps into the CSS file.
.pipe(plugins.sourcemaps.write())
.pipe(gulp.dest('./build/css'))
.pipe(plugins.livereload());
});
// Compile sass to css.
gulp.task('sass', function() {
return gulp.src('./sass/*.scss')
.pipe(sass.sync({outputStyle: 'compressed'}).on('error', sass.logError))
.pipe(plugins.autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
.pipe(gulp.dest('./build/css'))
.pipe(plugins.livereload());
});
// Zip app to upload on Google web store.
gulp.task('zip', () =>
gulp.src('build/**/**')
.pipe(plugins.zip('build.zip'))
.pipe(gulp.dest('./'))
);
gulp.task('popup-js', ['clean'], (cb) => {
webpack(popupWebpackConfig, (err, stats) => {
if (err) throw new plugins.util.PluginError('webpack', err);
// plugins.util.log('[webpack]', stats.toString());
plugins.livereload();
cb();
});
});
gulp.task('content-js', ['clean'], (cb) => {
webpack(contentWebpackConfig, (err, stats) => {
if (err) throw new plugins.util.PluginError('webpack', err);
// plugins.util.log('[webpack]', stats.toString());
plugins.livereload();
cb();
});
});
gulp.task('popup-html', ['clean'], () => {
return gulp.src('popup/index.html')
.pipe(plugins.rename('popup.html'))
.pipe(gulp.dest('./build'))
.pipe(plugins.livereload());
});
gulp.task('copy-manifest', ['clean'], () => {
return gulp.src('manifest.json')
.pipe(gulp.dest('./build'));
});
gulp.task('copy-libs', ['clean'], () => {
return gulp.src('./libs/*')
.pipe(gulp.dest('./build'));
});
gulp.task('copy-assets', ['clean'], () => {
return gulp.src('./assets/*')
.pipe(gulp.dest('./build/assets/'));
});
gulp.task('clean', (cb) => {
rimraf('./build', cb);
});
gulp.task('build', ['copy-manifest', 'copy-libs', 'copy-assets', 'popup-html', 'sass:dev', 'content-js', 'popup-js']);
gulp.task('watch', ['default'], () => {
plugins.livereload.listen();
gulp.watch('popup/**/*', ['build']);
gulp.watch('content/**/*', ['build']);
gulp.watch('background/**/*', ['build']);
gulp.watch('sass/*.scss', ['build']);
});
gulp.task('default', ['build']);