aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/gulpfile.js
diff options
context:
space:
mode:
authorStas Vilchik <vilchiks@gmail.com>2015-10-02 15:51:15 +0200
committerStas Vilchik <vilchiks@gmail.com>2015-10-14 10:28:59 +0200
commit15b2160babc5c35ede960b7d0e133acbec8c6c51 (patch)
tree6475ad0602bbe4d6dae895aae43d331726ab8c33 /server/sonar-web/gulpfile.js
parente51e9c9eb0145ea5e9d40453554c456585b79936 (diff)
downloadsonarqube-15b2160babc5c35ede960b7d0e133acbec8c6c51.tar.gz
sonarqube-15b2160babc5c35ede960b7d0e133acbec8c6c51.zip
improve the web build system, introduce gulp and browserify
Diffstat (limited to 'server/sonar-web/gulpfile.js')
-rw-r--r--server/sonar-web/gulpfile.js189
1 files changed, 189 insertions, 0 deletions
diff --git a/server/sonar-web/gulpfile.js b/server/sonar-web/gulpfile.js
new file mode 100644
index 00000000000..eedaca51f1d
--- /dev/null
+++ b/server/sonar-web/gulpfile.js
@@ -0,0 +1,189 @@
+var path = require('path');
+
+var glob = require('glob');
+var del = require('del');
+var browserify = require('browserify');
+var watchify = require('watchify');
+var es = require('event-stream');
+
+var gulp = require('gulp');
+var buffer = require('vinyl-buffer');
+var concat = require('gulp-concat');
+var gulpif = require('gulp-if');
+var less = require('gulp-less');
+var minifyCss = require('gulp-minify-css');
+var sourcemaps = require('gulp-sourcemaps');
+var uglify = require('gulp-uglify');
+
+var source = require('vinyl-source-stream');
+
+var argv = require('yargs').argv;
+var production = !argv.dev && !argv.fast;
+var dev = !!argv.dev && !argv.fast;
+var watch = !!argv.watch;
+var output = argv.output || './src/main/webapp';
+
+
+function getAppName (file) {
+ return file
+ .substr(0, file.length - 7)
+ .substr(17);
+}
+
+
+function doBrowserify (entry, sourceName, dest, customize) {
+ var bundler = browserify({
+ entries: [entry],
+ debug: dev,
+ cache: {},
+ packageCache: {}
+ });
+
+ // do all .require(), .external()
+ if (typeof customize === 'function') {
+ bundler = customize(bundler);
+ }
+
+ if (watch) {
+ bundler = watchify(bundler);
+ }
+
+ var rebundle = function (ids) {
+ if (ids) {
+ /* eslint no-console: 0 */
+ console.log(ids);
+ }
+ return bundler.bundle()
+ .pipe(source(sourceName))
+ .pipe(gulpif(production, buffer()))
+ .pipe(gulpif(production, uglify()))
+ .pipe(gulp.dest(path.join(output, dest)));
+ };
+
+ bundler.on('update', rebundle);
+
+ return rebundle();
+}
+
+
+gulp.task('scripts-sonar', function () {
+ return gulp.src([
+ 'src/main/js/libs/translate.js',
+ 'src/main/js/libs/third-party/jquery.js',
+ 'src/main/js/libs/third-party/jquery-ui.js',
+ 'src/main/js/libs/third-party/d3.js',
+ 'src/main/js/libs/third-party/underscore.js',
+ 'src/main/js/libs/third-party/select2.js',
+ 'src/main/js/libs/third-party/keymaster.js',
+ 'src/main/js/libs/third-party/moment.js',
+ 'src/main/js/libs/third-party/numeral.js',
+ 'src/main/js/libs/third-party/numeral-languages.js',
+ 'src/main/js/libs/third-party/bootstrap/tooltip.js',
+ 'src/main/js/libs/third-party/bootstrap/dropdown.js',
+ 'src/main/js/libs/select2-jquery-ui-fix.js',
+
+ 'src/main/js/libs/graphics/pie-chart.js',
+ 'src/main/js/libs/graphics/barchart.js',
+ 'src/main/js/libs/sortable.js',
+
+ 'src/main/js/libs/inputs.js',
+ 'src/main/js/libs/jquery-isolated-scroll.js',
+
+ 'src/main/js/libs/application.js'
+ ])
+ .pipe(concat('sonar.js'))
+ .pipe(gulpif(production, buffer()))
+ .pipe(gulpif(production, uglify()))
+ .pipe(gulp.dest(path.join(output, 'js')));
+});
+
+
+gulp.task('scripts-main', function () {
+ return doBrowserify(
+ 'src/main/js/main/app.js',
+ 'main.js',
+ 'js/bundles',
+ function (bundle) {
+ return bundle
+ .require('react', { expose: 'react' })
+ .require('backbone', { expose: 'backbone' })
+ .require('backbone.marionette', { expose: 'backbone.marionette' });
+ });
+});
+
+
+gulp.task('scripts-apps', function (done) {
+ glob('src/main/js/apps/*/app.js', function (err, files) {
+ if (err) {
+ done(err);
+ }
+
+ var tasks = files.map(function (entry) {
+ return doBrowserify(
+ entry,
+ getAppName(entry) + '.js',
+ 'js/bundles',
+ function (bundle) {
+ return bundle
+ .external('react')
+ .external('backbone')
+ .external('backbone.marionette');
+ }
+ );
+ });
+ es.merge(tasks).on('end', done);
+ });
+});
+
+gulp.task('scripts-widgets', function () {
+ return doBrowserify(
+ 'src/main/js/widgets/widgets.js',
+ 'widgets.js',
+ 'js/bundles',
+ function (bundle) {
+ return bundle
+ .external('react')
+ .external('backbone')
+ .external('backbone.marionette')
+ .require('./src/main/js/widgets/issue-filter/widget.js', { expose: 'issue-filter-widget' });
+ });
+});
+
+gulp.task('styles', function () {
+ return gulp.src([
+ 'src/main/less/jquery-ui.less',
+ 'src/main/less/select2.less',
+ 'src/main/less/select2-sonar.less',
+
+ 'src/main/less/init.less',
+ 'src/main/less/components.less',
+ 'src/main/less/pages.less',
+
+ 'src/main/less/style.less',
+
+ 'src/main/less/*.less'
+ ])
+ .pipe(gulpif(dev, sourcemaps.init()))
+ .pipe(less())
+ .pipe(gulpif(production, minifyCss()))
+ .pipe(concat('sonar.css'))
+ .pipe(gulpif(dev, sourcemaps.write({ includeContent: true })))
+ .pipe(gulp.dest(path.join(output, 'css')));
+});
+
+gulp.task('clean', function (done) {
+ del([
+ path.join(output, 'js'),
+ path.join(output, 'css')
+ ], done);
+});
+
+gulp.task('scripts', ['scripts-sonar', 'scripts-main', 'scripts-apps', 'scripts-widgets']);
+
+gulp.task('build', ['clean', 'scripts', 'styles'], function () {
+ if (watch) {
+ gulp.watch('src/main/less/**/*.less', ['styles']);
+ }
+});
+
+gulp.task('default', ['build']); \ No newline at end of file