Skip to content

Commit

Permalink
Chore: Adding rsync to yarn run watch (box#241)
Browse files Browse the repository at this point in the history
  • Loading branch information
Conrad Chan authored and pramodsum committed Oct 17, 2018
1 parent 6e9e97c commit 8bd6d50
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 1 deletion.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,5 @@ src/i18n/json
test/dev.html
lib
*~~bak
functional-tests/output
functional-tests/output
build/rsync.json
6 changes: 6 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,12 @@ Supported image file extensions: `ai, bmp, dcm, eps, gif, png, ps, psd, svs, tga
9. Test your first build! `yarn run build`
10. To test only local annotation changes, see [instantiating a custom instance of Box Annotations](https://github.com/box/box-annotations/#passing-an-instance-of-box-annotations-into-box-content-preview).
11. To link and test your local code changes along with your local Preview changes, run `yarn link` in this repository and `yarn link box-annotations` wherever [Box Content Preview](github.com/box/box-content-preview/) is cloned locally.
12. To automatically rsync files after a Webpack build, add a build/rsync.json file with a `location` field. This file should look like:
```
{
"location": "YOUR_DESIRED_RSYNC_LOCATION_HERE"
}
```

For more information on contributing see [Contributing](docs/contributing.md).

Expand Down
17 changes: 17 additions & 0 deletions build/RsyncPlugin.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
const execSync = require('child_process').execSync;

function RsyncPlugin(source, destination) {
this.source = source;
this.destination = destination;
}

/* eslint-disable no-console */
RsyncPlugin.prototype.apply = function rsync(compiler) {
compiler.plugin('done', () => {
console.log('');
console.log(`🔄 🔄 🔄 Rsync starting for ${this.source} 🔄 🔄 🔄`);
execSync(`rsync -avzq --exclude=".*" "${this.source}" "${this.destination}"`, { stdio: [0, 1, 2] });
});
};

module.exports = RsyncPlugin;
17 changes: 17 additions & 0 deletions build/webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,14 @@ require('babel-polyfill');
const path = require('path');
const CircularDependencyPlugin = require('circular-dependency-plugin');
const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const { BannerPlugin } = require('webpack');
const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const fs = require('fs');

const license = require('./license');
const RsyncPlugin = require('./RsyncPlugin');
const commonConfig = require('./webpack.common.config');
const TranslationsPlugin = require('./TranslationsPlugin');

Expand All @@ -14,6 +18,14 @@ const isDev = process.env.NODE_ENV === 'dev';
const language = process.env.LANGUAGE;
const locale = language.substr(0, language.indexOf('-'));

let rsyncLocation = '';
if (fs.existsSync('build/rsync.json')) {
/* eslint-disable */
const rsyncConf = require('./rsync.json');
rsyncLocation = rsyncConf.location;
/* eslint-enable */
}

/* eslint-disable key-spacing, require-jsdoc */
const config = Object.assign(commonConfig(), {
entry: {
Expand All @@ -35,6 +47,11 @@ const config = Object.assign(commonConfig(), {
});

if (isDev) {
// If build/rsync.json exists, rsync bundled files to specified directory
if (rsyncLocation) {
config.plugins.push(new RsyncPlugin('lib/.', rsyncLocation));
}

// Add inline source map
config.devtool = 'inline-source-map';
config.plugins.push(new TranslationsPlugin());
Expand Down

0 comments on commit 8bd6d50

Please sign in to comment.