shrub/pkg/interface/publish/gulpfile.js

186 lines
4.5 KiB
JavaScript
Raw Normal View History

2019-05-28 23:40:49 +03:00
var gulp = require('gulp');
var cssimport = require('gulp-cssimport');
var rollup = require('gulp-better-rollup');
2019-07-12 03:19:56 +03:00
var cssnano = require('cssnano');
var postcss = require('gulp-postcss')
2019-05-28 23:40:49 +03:00
var sucrase = require('@sucrase/gulp-plugin');
var minify = require('gulp-minify');
2019-07-25 01:13:21 +03:00
var rename = require('gulp-rename');
var del = require('del');
2019-05-28 23:40:49 +03:00
var resolve = require('rollup-plugin-node-resolve');
var commonjs = require('rollup-plugin-commonjs');
var rootImport = require('rollup-plugin-root-import');
var globals = require('rollup-plugin-node-globals');
/***
Main config options
***/
2019-07-23 23:08:04 +03:00
var urbitrc = require('../urbitrc');
2019-05-28 23:40:49 +03:00
/***
End main config options
***/
gulp.task('css-bundle', function() {
2019-07-12 03:19:56 +03:00
let plugins = [
cssnano()
];
2019-05-28 23:40:49 +03:00
return gulp
.src('src/index.css')
.pipe(cssimport())
2019-07-12 03:19:56 +03:00
.pipe(postcss(plugins))
2019-07-23 23:08:04 +03:00
.pipe(gulp.dest('../../arvo/app/publish/css'));
2019-05-28 23:40:49 +03:00
});
gulp.task('jsx-transform', function(cb) {
return gulp.src('src/**/*.js')
.pipe(sucrase({
transforms: ['jsx']
}))
.pipe(gulp.dest('dist'));
});
2019-06-21 23:16:25 +03:00
gulp.task('tile-jsx-transform', function(cb) {
return gulp.src('tile/**/*.js')
.pipe(sucrase({
transforms: ['jsx']
}))
.pipe(gulp.dest('dist'));
});
2019-05-28 23:40:49 +03:00
gulp.task('js-imports', function(cb) {
return gulp.src('dist/index.js')
.pipe(rollup({
plugins: [
commonjs({
namedExports: {
'node_modules/react/index.js': [ 'Component' ],
'node_modules/react-is/index.js': [ 'isValidElementType' ],
}
}),
rootImport({
root: `${__dirname}/dist/js`,
useEntry: 'prepend',
extensions: '.js'
}),
globals(),
resolve()
]
}, 'umd'))
.on('error', function(e){
console.log(e);
cb();
})
2019-07-23 23:08:04 +03:00
.pipe(gulp.dest('../../arvo/app/publish/js/'))
2019-05-28 23:40:49 +03:00
.on('end', cb);
});
2019-06-21 23:16:25 +03:00
gulp.task('tile-js-imports', function(cb) {
return gulp.src('dist/tile.js')
.pipe(rollup({
plugins: [
commonjs({
namedExports: {
'node_modules/react/index.js': [ 'Component' ],
}
}),
rootImport({
root: `${__dirname}/dist/js`,
useEntry: 'prepend',
extensions: '.js'
}),
globals(),
resolve()
]
}, 'umd'))
.on('error', function(e){
console.log(e);
cb();
})
2019-07-23 23:08:04 +03:00
.pipe(gulp.dest('../../arvo/app/publish/js/'))
2019-06-21 23:16:25 +03:00
.on('end', cb);
});
2019-05-28 23:40:49 +03:00
gulp.task('js-minify', function () {
2019-07-23 23:08:04 +03:00
return gulp.src('../../arvo/app/publish/js/index.js')
2019-05-28 23:40:49 +03:00
.pipe(minify())
2019-07-23 23:08:04 +03:00
.pipe(gulp.dest('../../arvo/app/publish/js/'));
2019-05-28 23:40:49 +03:00
});
gulp.task('tile-js-minify', function () {
2019-07-23 23:08:04 +03:00
return gulp.src('../../arvo/app/publish/js/tile.js')
.pipe(minify())
2019-07-23 23:08:04 +03:00
.pipe(gulp.dest('../../arvo/app/publish/js/'));
});
2019-07-25 01:13:21 +03:00
gulp.task('rename-index-min', function() {
return gulp.src('../../arvo/app/publish/js/index-min.js')
.pipe(rename('index.js'))
.pipe(gulp.dest('../../arvo/app/publish/js/'));
});
gulp.task('rename-tile-min', function() {
return gulp.src('../../arvo/app/publish/js/tile-min.js')
.pipe(rename('tile.js'))
.pipe(gulp.dest('../../arvo/app/publish/js/'));
});
gulp.task('clean-min', function() {
return del(['../../arvo/app/publish/js/index-min.js', '../../arvo/app/publish/js/tile-min.js'], {force: true})
});
2019-05-28 23:40:49 +03:00
gulp.task('urbit-copy', function () {
2019-07-23 23:08:04 +03:00
let ret = gulp.src('../../arvo/**/*');
2019-05-28 23:40:49 +03:00
urbitrc.URBIT_PIERS.forEach(function(pier) {
ret = ret.pipe(gulp.dest(pier));
});
return ret;
});
gulp.task('js-bundle-dev', gulp.series('jsx-transform', 'js-imports'));
2019-06-21 23:16:25 +03:00
gulp.task('tile-js-bundle-dev', gulp.series('tile-jsx-transform', 'tile-js-imports'));
gulp.task('js-bundle-prod', gulp.series('jsx-transform', 'js-imports', 'js-minify'))
2020-01-04 00:06:42 +03:00
gulp.task('tile-js-bundle-prod',
gulp.series('tile-jsx-transform', 'tile-js-imports', 'tile-js-minify'));
2019-05-28 23:40:49 +03:00
gulp.task('bundle-dev',
gulp.series(
gulp.parallel(
'css-bundle',
2019-06-21 23:16:25 +03:00
'js-bundle-dev',
'tile-js-bundle-dev'
2019-05-28 23:40:49 +03:00
),
'urbit-copy'
)
);
gulp.task('bundle-prod',
gulp.series(
gulp.parallel(
'css-bundle',
'js-bundle-prod',
'tile-js-bundle-prod',
2019-05-28 23:40:49 +03:00
),
2019-07-25 01:13:21 +03:00
'rename-index-min',
'rename-tile-min',
'clean-min',
'urbit-copy'
2019-05-28 23:40:49 +03:00
)
);
gulp.task('default', gulp.series('bundle-dev'));
2019-06-21 23:16:25 +03:00
2019-05-28 23:40:49 +03:00
gulp.task('watch', gulp.series('default', function() {
2019-06-21 23:16:25 +03:00
gulp.watch('tile/**/*.js', gulp.parallel('tile-js-bundle-dev'));
2019-05-28 23:40:49 +03:00
gulp.watch('src/**/*.js', gulp.parallel('js-bundle-dev'));
gulp.watch('src/**/*.css', gulp.parallel('css-bundle'));
2019-07-23 23:08:04 +03:00
gulp.watch('../../arvo/**/*', gulp.parallel('urbit-copy'));
2019-05-28 23:40:49 +03:00
}));