-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulpfile.js
314 lines (252 loc) · 8.11 KB
/
gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
/**
* Gulp file used for creating front end templates on local instances.
*/
'use strict';
// Configs
// Webpack Configs
const config = require( './config/general.config.js' );
const webpack_config_dev = require('./config/webpack.config.js');
const template_config = require( './config/template.data.js' );
// The gulp task runner
const gulp = require('gulp');
// CSS
const sass = require('gulp-sass');
const prefix = require('gulp-autoprefixer');
const sourcemaps = require('gulp-sourcemaps');
//Node Server
const nodemon = require('nodemon');
// Images
const imagemin = require('gulp-imagemin');
// HTML Templating, we use mustache to ensure it works with the Live Drupal site
const mustache = require('gulp-mustache');
// Javasript - WebPack Version
const webpack = require('webpack-stream');
const babel = require('gulp-babel');
const uglify = require('gulp-uglify');
// Browser Sync to auto refresh and keep things quick
const browserSync = require('browser-sync').create();
// General Use Packages
const rename = require('gulp-rename');
const fs = require('fs');
const git = require('gulp-git');
// Global
// Can be set either Dynamically using a date stamp or set manually by overriding the below with a string.
const _devFolder = config.development_folder || ".local_server";
const _prodFolder = config.production_folder || "prod";
const _imageFolderName = config.image_folder || "img";
let _logfile = "";
// Error handling
// Add the Error to the Browser Sync message so you can see it easily
function errorLog( $err ) {
console.log( $err );
browserSync.notify( '<span style="file-size: 22px;">Error : ' + $err + '</span>', 10000 );
this.emit('end');
}
function infoLog( $message ) {
const ts = new Date();
$message = '\n' + '[' + ts.getDate() + '/' + (ts.getMonth() + 1) + '/' + ts.getFullYear() + ' -- ' + ts.getHours() + ':' + ts.getMinutes() + '] ' + (_logfile === "" ? 'Info task started' : $message);
// grab the log file
if(_logfile === "") {
fs.readFile('./logs/.logfile.txt', 'utf8', function($err, $data) {
if($err) {
console.log('Error with logging file', $err);
} else {
// Store the data we have saved
_logfile = $data;
_logfile += $message;
// Write with the new message
fs.writeFile('./logs/.logfile.txt', _logfile, function () {
// file logged
return;
});
}
});
} else {
// Append the new message
_logfile += $message;
// If git changes exist then also write these out
git.exec({
args: 'log', function($err, $out) {
_logfile += "\n" + 'Git changes : ' + $out;
}
});
// Write to file
fs.writeFile('./logs/.logfile.txt', _logfile, function() {
// file logged
return;
});
}
}
// Browser Sync Server runing on default 3030 //
/*=====================================
= Watched Tasks =
=====================================*/
// Sass Task Runner
function sassTask() {
// Log this change
infoLog('Sass ran on files');
// Return the task
return gulp.src('./app/sass/**/*.scss')
.pipe(sourcemaps.init())
.pipe(sass({ outputStyle: 'compact', includePaths: ['./app/sass'] }) )
.on('error', errorLog )
.pipe( prefix({
browsers: ['last 2 versions']
}))
.pipe(sourcemaps.write('./'))
.pipe( gulp.dest('./' + _devFolder + '/css') )
};
//Node server task
function server() {
// configure nodemon
nodemon({
// the script to run the app
script: 'server/app.js',
// this listens to changes in any of these files/routes and restarts the application
watch: ["server/app.js"],
ext: 'js'
})
.on('restart', function () {
infoLog('restarted!')
});
};
// Scripts runner, this time using the Webpack Framework
function scripts() {
// Log this change
infoLog('Scripts ran on main.js');
// Return the task
return gulp.src('./app/scripts/main.js')
.pipe(webpack(
webpack_config_dev
))
.on('error', errorLog)
.pipe(gulp.dest('./' + _devFolder + '/js/'))
.on('error', errorLog)
};
// Scripts runner, this time using the Webpack Framework
gulp.task('minify', function () {
// Log this change
infoLog('Minify ran on the JS file');
// Return the task
return gulp.src('./prod/js/app.min.js')
.pipe(uglify())
.on('error', errorLog)
.pipe(gulp.dest('./' + _devFolder + '/js/'))
.on('error', errorLog);
});
// Template language compiler for taking Jade templates and moving them over to HTML files,
// this is an alternative to using the Jade Renderer on the Server
function mustacheTask(){
// Log this change
infoLog('Mustache Templates ran on the HTML files');
// Data for the site can be loaded via a JSON file
return gulp.src(['./app/views/*.mustache'])
.on('error', errorLog)
.pipe(
mustache( template_config )
)
.on('error', errorLog)
.pipe(rename(function(path){
path.extname = ".html";
}))
.pipe(gulp.dest('./' + _devFolder + '/'))
.on('error', errorLog)
.pipe(browserSync.stream());
};
/*=========================================
= Non Watched Tasks =
= all need to be self executed =
=========================================*/
// Scripts runner, converts all the third party JS and CSS etc. to a single vendor based file
// then compresses file and puts it in the correct folder.
function vendorJS() {
// Log this change
infoLog('Vendor JS Scripts ran');
// All the vendor JS
return gulp.src('./app/third_party/**/*.js')
.pipe( uglify() )
.pipe( gulp.dest('./' + _devFolder + '/js') );
};
function vendorCSS() {
// Log this change
infoLog('Vendor CSS Scripts ran');
// All the vendor CSS
return gulp.src('./app/third_party/**/*.css')
.pipe( gulp.dest('./' + _devFolder + '/css') );
};
function vendorWC() {
// Log this change
infoLog('Vendor web components Scripts ran');
return gulp.src('./app/third_party/web_components/**/*')
.pipe( gulp.dest('./' + _devFolder + '/web_components') );
};
// Clear out metadata from Photohshop Images and Shrink em' Down, has to be self exectued
// as there are a few bugs with del and watching etc.
function images() {
// Log this change
infoLog('Image Minification ran');
// Create the new images
return gulp.src('./app/images/**/*')
.pipe( imagemin({
progressive: true,
svgoPlugins: [{removeViewBox: false}]
}))
.on('error', errorLog )
.pipe(gulp.dest('./' + _devFolder + '/' + _imageFolderName + '/' ));
};
function browserSyncReload(done) {
browserSync.reload();
done();
}
function browserSyncServe(done) {
browserSync.init({
server: './' + _devFolder,
port: config.dev_port || 3030
});
done();
}
function watchTask() {
gulp.watch(['./app/scripts/**/*.jsx', './app/scripts/**/*.js'], gulp.series(scripts, browserSyncReload));
gulp.watch(['./app/**/*.scss'], gulp.series(sassTask, browserSyncReload));
gulp.watch(['./app/**/*.mustache', './app/**/*.json', './app/**/*.html'], gulp.series(mustacheTask, browserSyncReload));
}
const watch = gulp.parallel(gulp.series(images, mustacheTask, scripts, sassTask, browserSyncServe, watchTask), server);
exports.watch = watch;
const dev_server = gulp.series(images, mustacheTask, scripts, sassTask, browserSyncServe, watchTask);
exports.dev_server = dev_server;
const compile = gulp.series(images, mustacheTask, scripts, sassTask);
exports.compile = compile;
const vendor = gulp.series(vendorJS, vendorCSS, vendorWC);
exports.vendor = vendor;
exports.images = images;
exports.sass = sassTask;
function prodJS() {
// Log this change
infoLog('Setup JS for Prod');
// Javascript for Prod
return gulp.src('./' + _devFolder + "/js/**/*.js")
.pipe(babel({
presets: ['@babel/env', '@babel/preset-react']
}))
.pipe( uglify() )
.on('error', errorLog)
.pipe(gulp.dest('./' + _prodFolder + '/js/'));
}
function prodCSS() {
// Log this change
infoLog('Setup CSS for Prod');
// Sass for Prod
return gulp.src('./' + _devFolder + "/css/**/*.css")
.on('error', errorLog)
.pipe(gulp.dest('./' + _prodFolder + '/css/'));
}
function prodHTML() {
// Log this change
infoLog('Setup HTML for Prod');
// HTML for Prod
return gulp.src('./' + _devFolder + "/css/**/*.html")
.on('error', errorLog)
.pipe(gulp.dest('./' + _prodFolder + '/'));
}
const prod = gulp.series(images, mustacheTask, scripts, sassTask, prodJS, prodCSS, prodHTML)
exports.prod = prod;