blob: 6a8b99ee8e4219acce414e76dc95ae563a7e7dec [file] [log] [blame]
/*eslint-env node */
/*global require: true, module: true */
'use strict';
var options = require('../gulp-options.js'),
gulp = require('gulp'),
// Base dependencies
clean = require('gulp-clean'),
rename = require('gulp-rename'),
util = require('gulp-util'),
// Angular gulp dependencies
ngTemplateCache = require('gulp-angular-templatecache'),
ngAnnotate = require('gulp-ng-annotate'),
ngConstant = require('gulp-ng-constant'),
// Classical gulp dependencies
stripDebug = require('gulp-strip-debug'),
uglify = require('gulp-uglify'),
sass = require('gulp-sass'),
cleanCss = require('gulp-clean-css'),
rev = require('gulp-rev'),
revReplace = require('gulp-rev-replace'),
gulpIf = require('gulp-if'),
useref = require('gulp-useref'),
jsoncombine = require('gulp-jsoncombine'),
htmlParser = require('gulp-htmlparser');
var runSequence = require('run-sequence'),
es = require('event-stream');
gulp.task('webapp:clean', function () {
return gulp
.src([options.targetFolderPath + '/webapp', options.dirname + '/.temp'], { 'read': false })
.pipe(clean({'force': true}));
});
gulp.task('webapp:sasscompile', function () {
return gulp
.src('app/styles/index.scss')
.pipe(sass.sync().on('error', util.log))
.pipe(gulp.dest(options.srcFolderPath + '/styles'))
});
gulp.task('webapp:minifyvendorjs', function () {
return gulp
.src(options.bowerFolderPath + '/**/*.js')
.pipe(uglify({
preserveComments: 'false'
}))
.pipe(rename({suffix: '.min'}))
.pipe(gulp.dest(function(file) {
return file.base;
}))
});
// ----- To .temp from app
gulp.task('webapp:copyjs', function () {
return gulp.src(options.srcFolderPath + '/**/*.js')
.pipe(ngAnnotate()) // Check angular dependencies injection
.pipe(stripDebug()) // Remove all logs
.pipe(uglify({ 'mangle': false }))
.pipe(gulp.dest(options.dirname + '/.temp'));
});
gulp.task('webapp:copyothers', function () {
return gulp.src(['**/*', '!**/*.js', '!**/*.css', '!**/*.scss'], { 'cwd': options.srcFolderPath }) // All except JS files
.pipe(gulp.dest(options.tempFolderPath));
});
gulp.task('webapp:copycss', function () {
return gulp
.src('app/styles/index.css')
.pipe(cleanCss())
.pipe(gulp.dest(options.tempFolderPath + '/styles'));
});
gulp.task('webapp:constants', function () {
return gulp
.src('environment-constants.json')
.pipe(ngConstant({
'name': 'app.constants',
'deps': false
}))
.pipe(rename('environment-constants.js'))
.pipe(gulp.dest(options.tempFolderPath + '/constants'));
});
// ----- To target/webapp from .temp and bower_components
gulp.task('webapp:template', function () {
return gulp.src([options.srcFolderPath + '/**/*.html', '!' + options.srcFolderPath + '/index.html'])
.pipe(ngTemplateCache('templates.js', {
'module': 'app.templates',
'standalone': true
}))
.pipe(gulp.dest(options.tempFolderPath));
});
gulp.task('webapp:useref', function () {
var tasks = ['index.html'].map(function (indexPage) {
var assets = useref.assets({ });
return gulp.src(options.tempFolderPath + '/' + indexPage)
.pipe(assets)
.pipe(assets.restore())
.pipe(useref())
.pipe(revReplace()) // Force useref to apply the 'rev' method
.pipe(gulp.dest(options.targetFolderPath + '/webapp'));
});
return es.concat.apply(null, tasks);
});
gulp.task('webapp:copyresources', function () {
return gulp.src(['**/*.*', '!**/*.js', '!**/*.css', '!**/*.html', '!**/*.log'], { 'cwd': options.tempFolderPath })
.pipe(gulp.dest(options.targetFolderPath + '/webapp'));
});
module.exports = function (callback) {
return runSequence(
'webapp:clean',
'webapp:sasscompile',
'webapp:minifyvendorjs',
[
'webapp:copyjs',
'webapp:copycss',
'webapp:copyothers'
],
[
'webapp:constants',
'webapp:template'
],
[
'webapp:useref'
],
[
'webapp:copyresources'
],
callback
);
};