Skip to content

Instantly share code, notes, and snippets.

@bbachi
Created June 19, 2020 20:32
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save bbachi/f4fcf6249891b06f49cb0ea1f4a02d75 to your computer and use it in GitHub Desktop.
Save bbachi/f4fcf6249891b06f49cb0ea1f4a02d75 to your computer and use it in GitHub Desktop.
react nodejs dev
const { src, dest, series, parallel } = require('gulp');
const del = require('del');
const fs = require('fs');
const zip = require('gulp-zip');
const log = require('fancy-log');
const webpack_stream = require('webpack-stream');
const webpack_config = require('./webpack.config.js');
var exec = require('child_process').exec;
const paths = {
prod_build: '../prod-build',
server_file_name: 'server.bundle.js',
react_src: '../my-app/build/**/*',
react_dist: '../prod-build/my-app/build',
zipped_file_name: 'react-nodejs.zip'
};
function clean() {
log('removing the old files in the directory')
return del('../prod-build/**', {force:true});
}
function createProdBuildFolder() {
const dir = paths.prod_build;
log(`Creating the folder if not exist ${dir}`)
if(!fs.existsSync(dir)) {
fs.mkdirSync(dir);
log('📁 folder created:', dir);
}
return Promise.resolve('the value is ignored');
}
function buildReactCodeTask(cb) {
log('building React code into the directory')
return exec('cd ../my-app && npm run build', function (err, stdout, stderr) {
log(stdout);
log(stderr);
cb(err);
})
}
function copyReactCodeTask() {
log('copying React code into the directory')
return src(`${paths.react_src}`)
.pipe(dest(`${paths.react_dist}`));
}
function copyNodeJSCodeTask() {
log('building and copying server code into the directory')
return webpack_stream(webpack_config)
.pipe(dest(`${paths.prod_build}`))
}
function zippingTask() {
log('zipping the code ')
return src(`${paths.prod_build}/**`)
.pipe(zip(`${paths.zipped_file_name}`))
.pipe(dest(`${paths.prod_build}`))
}
exports.default = series(
clean,
createProdBuildFolder,
buildReactCodeTask,
parallel(copyReactCodeTask, copyNodeJSCodeTask),
zippingTask
);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment