blob: d71151b4823cc9d066197923b2556c88bcd13a92 [file] [log] [blame]
Matteo Scandolod7552052016-03-11 13:47:27 -08001'use strict';
2
3// BUILD
4//
5// 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
8//
9// The template are parsed and added to js with angular $templateCache
10
11var gulp = require('gulp');
12var ngAnnotate = require('gulp-ng-annotate');
13var uglify = require('gulp-uglify');
14var templateCache = require('gulp-angular-templatecache');
15var runSequence = require('run-sequence');
Matteo Scandolo280dcd32016-05-16 09:59:38 -070016var concat = require('gulp-concat-util');
Matteo Scandolod7552052016-03-11 13:47:27 -080017var del = require('del');
18var wiredep = require('wiredep');
19var angularFilesort = require('gulp-angular-filesort');
20var _ = require('lodash');
21var eslint = require('gulp-eslint');
22var inject = require('gulp-inject');
23var rename = require('gulp-rename');
24var replace = require('gulp-replace');
Matteo Scandoloa448f7d2016-03-11 13:53:12 -080025var postcss = require('gulp-postcss');
26var autoprefixer = require('autoprefixer');
27var mqpacker = require('css-mqpacker');
28var csswring = require('csswring');
Matteo Scandoloeaa69222016-08-05 15:24:28 -070029var yaml = require('js-yaml');
30var colors = require('colors/safe');
Matteo Scandolod7552052016-03-11 13:47:27 -080031
Matteo Scandolo280dcd32016-05-16 09:59:38 -070032const TEMPLATE_FOOTER = `
33angular.module('xos.truckroll')
34.run(['$location', function(a){
35 a.path('/');
36}])
37`
Matteo Scandolod7552052016-03-11 13:47:27 -080038
39module.exports = function(options){
40
41 // delete previous builded file
42 gulp.task('clean', function(){
43 return del(
Matteo Scandolo280dcd32016-05-16 09:59:38 -070044 [
45 options.dashboards + 'xosTruckroll.html',
Matteo Scandolo195dde92016-07-25 16:43:16 -070046 options.static + 'css/xosTruckroll.css',
47 options.static + 'images/truckroll-icon.png',
48 options.static + 'images/truckroll-icon-active.png'
Matteo Scandolo280dcd32016-05-16 09:59:38 -070049 ],
Matteo Scandolod7552052016-03-11 13:47:27 -080050 {force: true}
51 );
52 });
53
54 // minify css
55 gulp.task('css', function () {
56 var processors = [
57 autoprefixer({browsers: ['last 1 version']}),
58 mqpacker,
59 csswring
60 ];
Matteo Scandoloa448f7d2016-03-11 13:53:12 -080061
Matteo Scandolod7552052016-03-11 13:47:27 -080062 gulp.src([
63 `${options.css}**/*.css`,
64 `!${options.css}dev.css`
65 ])
66 .pipe(postcss(processors))
67 .pipe(gulp.dest(options.tmp + '/css/'));
68 });
69
Matteo Scandolo280dcd32016-05-16 09:59:38 -070070 // copy css in correct folder
71 gulp.task('copyCss', ['wait'], function(){
Matteo Scandolod7552052016-03-11 13:47:27 -080072 return gulp.src([`${options.tmp}/css/*.css`])
Matteo Scandoloa448f7d2016-03-11 13:53:12 -080073 .pipe(concat('xosTruckroll.css'))
Matteo Scandolod7552052016-03-11 13:47:27 -080074 .pipe(gulp.dest(options.static + 'css/'))
75 });
76
Matteo Scandolo195dde92016-07-25 16:43:16 -070077 // copy images in correct folder
78 gulp.task('copyImages', ['wait'], function(){
79 return gulp.src([`${options.icon}/truckroll-icon.png`,`${options.icon}/truckroll-icon-active.png`])
80 .pipe(gulp.dest(options.static + 'images/'))
81 });
82
Matteo Scandolod7552052016-03-11 13:47:27 -080083 // compile and minify scripts
84 gulp.task('scripts', function() {
85 return gulp.src([
86 options.tmp + '**/*.js'
87 ])
88 .pipe(ngAnnotate())
89 .pipe(angularFilesort())
90 .pipe(concat('xosTruckroll.js'))
Matteo Scandolo280dcd32016-05-16 09:59:38 -070091 .pipe(concat.header('//Autogenerated, do not edit!!!\n'))
92 .pipe(concat.footer(TEMPLATE_FOOTER))
Matteo Scandolod7552052016-03-11 13:47:27 -080093 .pipe(uglify())
94 .pipe(gulp.dest(options.static + 'js/'));
95 });
96
97 // set templates in cache
98 gulp.task('templates', function(){
99 return gulp.src('./src/templates/*.html')
100 .pipe(templateCache({
101 module: 'xos.truckroll',
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700102 root: 'templates/'
Matteo Scandolod7552052016-03-11 13:47:27 -0800103 }))
104 .pipe(gulp.dest(options.tmp));
105 });
106
107 // copy html index to Django Folder
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700108 gulp.task('copyHtml', function(){
Matteo Scandolod7552052016-03-11 13:47:27 -0800109 return gulp.src(options.src + 'index.html')
110 // remove dev dependencies from html
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700111 .pipe(replace(/<!-- bower:css -->(\n^<link.*)*\n<!-- endbower -->/gmi, ''))
112 .pipe(replace(/<!-- bower:js -->(\n^<script.*)*\n<!-- endbower -->/gmi, ''))
Matteo Scandolod7552052016-03-11 13:47:27 -0800113 // injecting minified files
114 .pipe(
115 inject(
116 gulp.src([
Matteo Scandolo195dde92016-07-25 16:43:16 -0700117 options.static + 'vendor/xosTruckrollVendor.js',
Matteo Scandolocc9930e2016-03-11 15:01:01 -0800118 options.static + 'js/xosTruckroll.js',
119 options.static + 'css/xosTruckroll.css'
Matteo Scandolod7552052016-03-11 13:47:27 -0800120 ]),
121 {ignorePath: '/../../../xos/core/xoslib'}
122 )
123 )
124 .pipe(rename('xosTruckroll.html'))
125 .pipe(gulp.dest(options.dashboards));
126 });
127
128 // minify vendor js files
129 gulp.task('wiredep', function(){
130 var bowerDeps = wiredep().js;
131 if(!bowerDeps){
132 return;
133 }
134
135 // remove angular (it's already loaded)
136 _.remove(bowerDeps, function(dep){
137 return dep.indexOf('angular/angular.js') !== -1;
138 });
139
140 return gulp.src(bowerDeps)
141 .pipe(concat('xosTruckrollVendor.js'))
142 .pipe(uglify())
Matteo Scandolo195dde92016-07-25 16:43:16 -0700143 .pipe(gulp.dest(options.static + 'vendor/'));
Matteo Scandolod7552052016-03-11 13:47:27 -0800144 });
145
146 gulp.task('lint', function () {
147 return gulp.src(['src/js/**/*.js'])
148 .pipe(eslint())
149 .pipe(eslint.format())
150 .pipe(eslint.failAfterError());
151 });
152
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700153 gulp.task('wait', function (cb) {
154 // setTimeout could be any async task
155 setTimeout(function () {
156 cb();
157 }, 1000);
158 });
159
Matteo Scandoloeaa69222016-08-05 15:24:28 -0700160 gulp.task('tosca', function (cb) {
161
162 // TOSCA to register the dashboard in the system
163 const dashboardJson = {};
164 dashboardJson['Truckroll'] = {
165 type: 'tosca.nodes.DashboardView',
166 properties: {
167 url: 'template:xosTruckroll'
168 }
169 };
170 const dashboardTosca = yaml.dump(dashboardJson).replace(/'/gmi, '');
171
172 // TOSCA to add the dashboard to the user
173 const userDashboardJson = {};
174 userDashboardJson['truckroll_dashboard'] = {
175 node: 'Truckroll',
176 relationship: 'tosca.relationships.UsesDashboard'
177 };
178 const userJson = {
179 'padmin@vicci.org': {
180 type: 'tosca.nodes.User',
181 properties: {
182 'no-create': true,
183 'no-delete': true
184 },
185 requirements: [userDashboardJson]
186 }
187 };
188 const userTosca = yaml.dump(userJson).replace(/'/gmi, '');
189
190
191 // the output is in a timeout so that it get printed after the gulp logs
192 setTimeout(function () {
193 console.log(colors.cyan('\n\n# You can use this recipe to load the dashboard in the system:'));
194 console.log(colors.yellow(dashboardTosca));
195 console.log(colors.cyan('# And this recipe to activate the dashboard for a user:'));
196 console.log(colors.yellow(userTosca));
197 }, 1000);
198 cb();
199 });
200
Matteo Scandolod7552052016-03-11 13:47:27 -0800201 gulp.task('build', function() {
202 runSequence(
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700203 'clean',
204 'sass',
Matteo Scandolod7552052016-03-11 13:47:27 -0800205 'templates',
206 'babel',
207 'scripts',
208 'wiredep',
Matteo Scandolo280dcd32016-05-16 09:59:38 -0700209 'css',
210 'copyCss',
Matteo Scandolo195dde92016-07-25 16:43:16 -0700211 'copyImages',
Matteo Scandolod7552052016-03-11 13:47:27 -0800212 'copyHtml',
Matteo Scandoloeaa69222016-08-05 15:24:28 -0700213 'cleanTmp',
214 'tosca'
Matteo Scandolod7552052016-03-11 13:47:27 -0800215 );
216 });
217};