blob: 22d56660df560ad74e576afd08993280ea4a0efe [file] [log] [blame]
Matteo Scandolo8cc22e42016-04-12 09:00:04 -07001'use strict';
2
3var gulp = require('gulp');
4var browserSync = require('browser-sync').create();
5var inject = require('gulp-inject');
Matteo Scandolob7a86dc2016-04-14 11:46:30 -07006var es = require('event-stream');
Matteo Scandolo8cc22e42016-04-12 09:00:04 -07007var runSequence = require('run-sequence');
8var angularFilesort = require('gulp-angular-filesort');
9var babel = require('gulp-babel');
10var wiredep = require('wiredep').stream;
11var httpProxy = require('http-proxy');
12var del = require('del');
13var sass = require('gulp-sass');
Matteo Scandolob7a86dc2016-04-14 11:46:30 -070014var debug = require('gulp-debug');
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070015
16const environment = process.env.NODE_ENV;
17
18if (environment){
19 var conf = require(`../env/${environment}.js`);
20}
21else{
22 var conf = require('../env/default.js')
23}
24
25var proxy = httpProxy.createProxyServer({
26 target: conf.host || 'http://0.0.0.0:9999'
27});
28
29
30proxy.on('error', function(error, req, res) {
31 res.writeHead(500, {
32 'Content-Type': 'text/plain'
33 });
34
35 console.error('[Proxy]', error);
36});
37
38module.exports = function(options){
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070039 // open in browser with sync and proxy to 0.0.0.0
40 gulp.task('browser', function() {
Matteo Scandolo1ba8b302016-04-14 10:53:30 -070041 console.log(options.helpers);
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070042 browserSync.init({
43 // reloadDelay: 500,
44 // logLevel: 'debug',
45 // logConnections: true,
46 startPath: '#/',
47 snippetOptions: {
48 rule: {
49 match: /<!-- browserSync -->/i
50 }
51 },
52 server: {
53 baseDir: options.src,
54 routes: {
Matteo Scandolo1ba8b302016-04-14 10:53:30 -070055 // '/xosHelpers/src': options.helpers,
Matteo Scandolo90ed0642016-04-25 10:11:56 -070056 '/xos/core/xoslib/static/js/vendor': options.helpers,
57 '/xos/core/static': options.static + '../../static/'
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070058 },
59 middleware: function(req, res, next){
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070060 if(
Matteo Scandolo1ba8b302016-04-14 10:53:30 -070061 // req.url.indexOf('/xos/') !== -1 ||
62 // req.url.indexOf('/xoslib/') !== -1 ||
63 // req.url.indexOf('/hpcapi/') !== -1 ||
Matteo Scandolobd2e5cd2016-04-12 11:59:29 -070064 req.url.indexOf('/api/') !== -1
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070065 ){
66 if(conf.xoscsrftoken && conf.xossessionid){
67 req.headers.cookie = `xoscsrftoken=${conf.xoscsrftoken}; xossessionid=${conf.xossessionid}`;
68 req.headers['x-csrftoken'] = conf.xoscsrftoken;
69 }
70 proxy.web(req, res);
71 }
72 else{
73 next();
74 }
75 }
76 }
77 });
78
79 gulp.watch(options.src + 'js/**/*.js', ['js-watch']);
80 gulp.watch(options.src + 'vendor/**/*.js', ['bower'], function(){
81 browserSync.reload();
82 });
83 gulp.watch(options.src + '**/*.html', function(){
84 browserSync.reload();
85 });
86 gulp.watch(options.css + '**/*.css', function(){
87 browserSync.reload();
88 });
Matteo Scandolob7a86dc2016-04-14 11:46:30 -070089
90 gulp.watch(options.helpers + 'ngXosHelpers.js', function(){
91 browserSync.reload();
92 });
93
Matteo Scandolo8cc22e42016-04-12 09:00:04 -070094 gulp.watch(`${options.sass}/**/*.scss`, ['sass'], function(){
95 browserSync.reload();
96 });
97 });
98
99 // compile sass
100 gulp.task('sass', function () {
101 return gulp.src(`${options.sass}/**/*.scss`)
102 .pipe(sass().on('error', sass.logError))
103 .pipe(gulp.dest(options.css));
104 });
105
106 // transpile js with sourceMaps
107 gulp.task('babel', function(){
108 return gulp.src(options.scripts + '**/*.js')
109 .pipe(babel({sourceMaps: true}))
110 .pipe(gulp.dest(options.tmp));
111 });
112
Matteo Scandolob7a86dc2016-04-14 11:46:30 -0700113 // // inject sourceMap
114 // gulp.task('injectMaps', function(){
115 // return gulp.src(options.src + 'index.html')
116 // .pipe(
117 // inject(
118 // gulp.src([
119 // options.helpersSourceMaps + '**/*.js.map'
120 // ], {read: false}).pipe(debug()),
121 // {
122 // starttag: '<!-- inject:maps -->',
123 // // ignorePath: [options.src, '/../../ngXosLib']
124 // }
125 // )
126 // )
127 // .pipe(gulp.dest(options.src));
128 // });
129
Matteo Scandolo8cc22e42016-04-12 09:00:04 -0700130 // inject scripts
131 gulp.task('injectScript', ['cleanTmp', 'babel'], function(){
Matteo Scandolob7a86dc2016-04-14 11:46:30 -0700132
133 var appScripts = gulp.src([
134 options.tmp + '**/*.js',
135 options.helpers + 'ngXosHelpers.js'
136 ])
137 .pipe(angularFilesort()).pipe(debug());
138
139 var helpersSourceMaps = gulp.src([
140 options.helpersSourceMaps + '**/*.js.map'
141 ]).pipe(debug());
142
Matteo Scandolo8cc22e42016-04-12 09:00:04 -0700143 return gulp.src(options.src + 'index.html')
144 .pipe(
145 inject(
Matteo Scandolob7a86dc2016-04-14 11:46:30 -0700146 es.merge(appScripts, helpersSourceMaps),
Matteo Scandolo8cc22e42016-04-12 09:00:04 -0700147 {
148 ignorePath: [options.src, '/../../ngXosLib']
149 }
150 )
151 )
152 .pipe(gulp.dest(options.src));
153 });
154
155 // inject CSS
156 gulp.task('injectCss', function(){
157 return gulp.src(options.src + 'index.html')
158 .pipe(
159 inject(
Matteo Scandolo90ed0642016-04-25 10:11:56 -0700160 gulp.src([
161 options.src + 'css/*.css',
162 options.static + '../../static/xosNgLib.css'
163 ]),
Matteo Scandolo8cc22e42016-04-12 09:00:04 -0700164 {
165 ignorePath: [options.src]
166 }
167 )
168 )
169 .pipe(gulp.dest(options.src));
170 });
171
172 // inject bower dependencies with wiredep
173 gulp.task('bower', function () {
174 return gulp.src(options.src + 'index.html')
175 .pipe(wiredep({devDependencies: true}))
176 .pipe(gulp.dest(options.src));
177 });
178
179 gulp.task('js-watch', ['injectScript'], function(){
180 browserSync.reload();
181 });
182
183 gulp.task('cleanTmp', function(){
184 return del([options.tmp + '**/*']);
185 });
186
187 gulp.task('serve', function() {
188 runSequence(
189 'sass',
190 'bower',
191 'injectScript',
192 'injectCss',
193 ['browser']
194 );
195 });
196};