-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
42 lines (37 loc) · 1.23 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
/**
* Besan Block plugin gulp scripts.
*/
// Declare gulp libraries.
const gulp = require( 'gulp' ),
browserify = require( 'browserify' ),
buffer = require( 'vinyl-buffer' ),
rename = require( 'gulp-rename' ),
sass = require( 'gulp-dart-sass' ),
source = require( 'vinyl-source-stream' ),
uglify = require( 'gulp-uglify' );
// Array of JS files, in order by dependency.
const jsFiles = [
'besan-block/source/blocks/chart/index.js'
];
// Task function to build the JS files.
function buildJs() {
return browserify( { entries: jsFiles } )
.transform( 'babelify', { presets: [ "@babel/preset-env", "@babel/preset-react" ] } )
.bundle()
.pipe( source( 'besan-block.min.js' ) )
.pipe( buffer() )
.pipe( uglify() )
.pipe( gulp.dest( 'besan-block/build' ) );
}
// Task function to build the CSS files.
function buildEditorCss() {
return gulp.src( 'besan-block/source/scss/editor.scss' )
.pipe( sass( { outputStyle: 'compressed' } ) )
.pipe( rename( {
basename: 'besan-block-editor',
suffix: '.min'
} ) )
.pipe( gulp.dest( 'besan-block/build' ) );
}
// Task definitions.
gulp.task( 'default', gulp.series( buildJs, buildEditorCss ) );