blob: b2dd6ca755adbc1988d93907df45c6d34ecc893f [file] [log] [blame]
Matteo Scandolo608f91d2015-10-29 11:54:54 +01001'use strict';
2
3// BUILD
Matteo Scandolod44ceb42015-11-06 17:14:28 +01004//
Matteo Scandolo608f91d2015-10-29 11:54:54 +01005// The only purpose of this gulpfile is to build a XOS view and copy the correct files into
6// .html => dashboards
7// .js (minified and concat) => static/js
Matteo Scandolod44ceb42015-11-06 17:14:28 +01008//
Matteo Scandolo608f91d2015-10-29 11:54:54 +01009// The template are parsed and added to js with angular $templateCache
10
11var gulp = require('gulp');
Matteo Scandolobbcc01b2015-11-04 16:30:43 +010012var ngAnnotate = require('gulp-ng-annotate');
Matteo Scandolo608f91d2015-10-29 11:54:54 +010013var uglify = require('gulp-uglify');
14var templateCache = require('gulp-angular-templatecache');
15var runSequence = require('run-sequence');
Matteo Scandolo97532ef2016-05-17 17:12:03 -070016var concat = require('gulp-concat-util');
Matteo Scandolo608f91d2015-10-29 11:54:54 +010017var del = require('del');
18var wiredep = require('wiredep');
Matteo Scandolo6d972642015-10-29 15:50:15 +010019var angularFilesort = require('gulp-angular-filesort');
Matteo Scandolobbcc01b2015-11-04 16:30:43 +010020var _ = require('lodash');
Matteo Scandolod44ceb42015-11-06 17:14:28 +010021var eslint = require('gulp-eslint');
22var inject = require('gulp-inject');
23var rename = require('gulp-rename');
24var replace = require('gulp-replace');
Matteo Scandolo97532ef2016-05-17 17:12:03 -070025var postcss = require('gulp-postcss');
26var autoprefixer = require('autoprefixer');
27var mqpacker = require('css-mqpacker');
28var csswring = require('csswring');
Matteo Scandolo262385f2016-08-08 09:28:14 -070029var yaml = require('js-yaml');
30var colors = require('colors/safe');
31var fs = require('fs');
Matteo Scandolo608f91d2015-10-29 11:54:54 +010032
Matteo Scandolo97532ef2016-05-17 17:12:03 -070033const TEMPLATE_FOOTER = `
34angular.module('xos.contentProvider')
35.run(['$location', function(a){
36 a.path('/');
37}])
38`
Matteo Scandolo9a607262015-11-10 17:13:04 +010039
Matteo Scandolo608f91d2015-10-29 11:54:54 +010040module.exports = function(options){
Matteo Scandoloc2d0f532015-10-29 16:13:35 +010041
Matteo Scandolod44ceb42015-11-06 17:14:28 +010042 // delete previous builded file
Matteo Scandolo608f91d2015-10-29 11:54:54 +010043 gulp.task('clean', function(){
Matteo Scandolod44ceb42015-11-06 17:14:28 +010044 return del(
Matteo Scandolo97532ef2016-05-17 17:12:03 -070045 [
46 options.dashboards + 'xosContentProvider.html',
Matteo Scandolo195dde92016-07-25 16:43:16 -070047 options.static + 'css/xosContentProvider.css',
48 options.static + 'images/contentProvider-icon.png',
49 options.static + 'images/contentProvider-icon-active.png'
Matteo Scandolo97532ef2016-05-17 17:12:03 -070050 ],
Matteo Scandolod44ceb42015-11-06 17:14:28 +010051 {force: true}
52 );
Matteo Scandolo608f91d2015-10-29 11:54:54 +010053 });
54
Matteo Scandolo97532ef2016-05-17 17:12:03 -070055 // minify css
56 gulp.task('css', function () {
57 var processors = [
58 autoprefixer({browsers: ['last 1 version']}),
59 mqpacker,
60 csswring
61 ];
62
63 gulp.src([
64 `${options.css}**/*.css`,
65 `!${options.css}dev.css`
66 ])
67 .pipe(postcss(processors))
68 .pipe(gulp.dest(options.tmp + '/css/'));
69 });
70
71 // copy css in correct folder
72 gulp.task('copyCss', ['wait'], function(){
73 return gulp.src([`${options.tmp}/css/*.css`])
74 .pipe(concat('xosContentProvider.css'))
75 .pipe(gulp.dest(options.static + 'css/'))
76 });
77
Matteo Scandolo195dde92016-07-25 16:43:16 -070078 // copy images in correct folder
79 gulp.task('copyImages', ['wait'], function(){
Matteo Scandolo262385f2016-08-08 09:28:14 -070080 return gulp.src([`${options.icon}/contentProvider-icon.png`, `${options.icon}/contentProvider-icon-active.png`])
Matteo Scandolo195dde92016-07-25 16:43:16 -070081 .pipe(gulp.dest(options.static + 'images/'))
82 });
83
Matteo Scandoloc2d0f532015-10-29 16:13:35 +010084 // compile and minify scripts
Matteo Scandolo608f91d2015-10-29 11:54:54 +010085 gulp.task('scripts', function() {
86 return gulp.src([
Matteo Scandolod44ceb42015-11-06 17:14:28 +010087 options.tmp + '**/*.js'
88 ])
89 .pipe(ngAnnotate())
90 .pipe(angularFilesort())
91 .pipe(concat('xosContentProvider.js'))
Matteo Scandolo97532ef2016-05-17 17:12:03 -070092 .pipe(concat.header('//Autogenerated, do not edit!!!\n'))
93 .pipe(concat.footer(TEMPLATE_FOOTER))
Matteo Scandolod44ceb42015-11-06 17:14:28 +010094 .pipe(uglify())
95 .pipe(gulp.dest(options.static + 'js/'));
Matteo Scandolo608f91d2015-10-29 11:54:54 +010096 });
97
Matteo Scandoloc2d0f532015-10-29 16:13:35 +010098 // set templates in cache
Matteo Scandolo608f91d2015-10-29 11:54:54 +010099 gulp.task('templates', function(){
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100100 return gulp.src('./src/templates/*.html')
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100101 .pipe(templateCache({
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100102 module: 'xos.contentProvider',
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700103 root: 'templates/'
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100104 }))
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100105 .pipe(gulp.dest(options.tmp));
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100106 });
107
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100108 // copy html index to Django Folder
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700109 gulp.task('copyHtml', function(){
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100110 return gulp.src(options.src + 'index.html')
111 // remove dev dependencies from html
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700112 .pipe(replace(/<!-- bower:css -->(\n^<link.*)*\n<!-- endbower -->/gmi, ''))
113 .pipe(replace(/<!-- bower:js -->(\n^<script.*)*\n<!-- endbower -->/gmi, ''))
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100114 // injecting minified files
115 .pipe(
116 inject(
117 gulp.src([
Matteo Scandolo195dde92016-07-25 16:43:16 -0700118 options.static + 'vendor/xosContentProviderVendor.js',
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700119 options.static + 'js/xosContentProvider.js',
120 options.static + 'css/xosContentProvider.css'
Matteo Scandoloc0c94092016-02-02 17:25:18 -0800121 ]),
122 {ignorePath: '/../../../xos/core/xoslib'}
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100123 )
124 )
125 .pipe(rename('xosContentProvider.html'))
126 .pipe(gulp.dest(options.dashboards));
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100127 });
128
Matteo Scandoloc2d0f532015-10-29 16:13:35 +0100129 // minify vendor js files
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100130 gulp.task('wiredep', function(){
131 var bowerDeps = wiredep().js;
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100132 if(!bowerDeps){
133 return;
134 }
135
136 // remove angular (it's already loaded)
137 _.remove(bowerDeps, function(dep){
138 return dep.indexOf('angular/angular.js') !== -1;
139 });
140
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100141 return gulp.src(bowerDeps)
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100142 .pipe(concat('xosContentProviderVendor.js'))
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100143 .pipe(uglify())
Matteo Scandolo195dde92016-07-25 16:43:16 -0700144 .pipe(gulp.dest(options.static + 'vendor/'));
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100145 });
146
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100147 gulp.task('lint', function () {
148 return gulp.src(['src/js/**/*.js'])
149 .pipe(eslint())
150 .pipe(eslint.format())
151 .pipe(eslint.failAfterError());
152 });
Matteo Scandoloc2d0f532015-10-29 16:13:35 +0100153
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700154 gulp.task('wait', function (cb) {
155 // setTimeout could be any async task
156 setTimeout(function () {
157 cb();
158 }, 1000);
159 });
160
Matteo Scandolo262385f2016-08-08 09:28:14 -0700161 gulp.task('tosca', function (cb) {
162
163 // TOSCA to register the dashboard in the system
164 const dashboardJson = {};
165 dashboardJson['ContentProvider'] = {
166 type: 'tosca.nodes.DashboardView',
167 properties: {
168 url: 'template:xosContentProvider'
169 }
170 };
171
172 // check for custom icons
173 if(
174 fs.existsSync(`${options.icon}/contentProvider-icon.png`) &&
175 fs.existsSync(`${options.icon}/contentProvider-icon-active.png`)
176 ){
177 dashboardJson['ContentProvider'].properties.custom_icon = true;
178 }
179
180 const dashboardTosca = yaml.dump(dashboardJson).replace(/'/gmi, '');
181
182 // TOSCA to add the dashboard to the user
183 const userDashboardJson = {};
184 userDashboardJson['contentProvider_dashboard'] = {
185 node: 'ContentProvider',
186 relationship: 'tosca.relationships.UsesDashboard'
187 };
188 const userJson = {
189 'padmin@vicci.org': {
190 type: 'tosca.nodes.User',
191 properties: {
192 'no-create': true,
193 'no-delete': true
194 },
195 requirements: [userDashboardJson]
196 }
197 };
198 const userTosca = yaml.dump(userJson).replace(/'/gmi, '');
199
200
201 // the output is in a timeout so that it get printed after the gulp logs
202 setTimeout(function () {
203 console.log(colors.cyan('\n\n# You can use this recipe to load the dashboard in the system:'));
204 console.log(colors.yellow(dashboardTosca));
205 console.log(colors.cyan('# And this recipe to activate the dashboard for a user:'));
206 console.log(colors.yellow(userTosca));
207 }, 1000);
208 cb();
209 });
210
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100211 gulp.task('build', function() {
212 runSequence(
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700213 'clean',
214 'sass',
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100215 'templates',
Matteo Scandolobbcc01b2015-11-04 16:30:43 +0100216 'babel',
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100217 'scripts',
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100218 'wiredep',
Matteo Scandolo97532ef2016-05-17 17:12:03 -0700219 'css',
220 'copyCss',
Matteo Scandolo195dde92016-07-25 16:43:16 -0700221 'copyImages',
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100222 'copyHtml',
Matteo Scandolo262385f2016-08-08 09:28:14 -0700223 'cleanTmp',
224 'tosca'
Matteo Scandolo608f91d2015-10-29 11:54:54 +0100225 );
226 });
Matteo Scandolod44ceb42015-11-06 17:14:28 +0100227};