-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
133 lines (106 loc) · 5.52 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
var gulp = require('gulp');
var path = require('path');
var fs = require('fs');
//██████████ GULP PLUGINS ███████████████
var gutil = require('gulp-util');
var uglifyjs = require('uglify-es');
var composer = require('gulp-uglify/composer');
var uglify = composer(uglifyjs, console);
var sourcemaps = require('gulp-sourcemaps');
var include = require('gulp-include');
const sass = require('gulp-sass')(require('sass'));
var handlebars = require('gulp-hb');
var rename = require("gulp-rename");
var imagemin = require("gulp-imagemin");
var through = require('through2');
var generateThumbnails = require('./generate-thumbnails.js');
//████████████████████████████████████████████████████████████████████████████████
//██████████████████████████████ ENVIRONMENT █████████████████████████████████████
//████████████████████████████████████████████████████████████████████████████████
const LIVE = process.env.LIVE;
console.log('ENV:',LIVE?'live':'dev');
const environments = require('gulp-environments');
const liveOnly = environments.make('live');
environments.current(LIVE?'live':'dev');
const cssStyle = LIVE?'compressed':'nested';
//████████████████████████████████████████████████████████████████████████████████
//████████████████████████████████ TASKS █████████████████████████████████████████
//████████████████████████████████████████████████████████████████████████████████
//html task - copies html files
gulp.task("html", function () {
return gulp.src('html/*.htm')
.pipe(gulp.dest("./build"));
});
//favicon task - copies favicon file
gulp.task("favicon", function () {
return gulp.src('design/favicon.ico')
.pipe(gulp.dest("./build"));
});
//models task - copies model files
gulp.task("models", function () {
return gulp.src('models/*.glb')
.pipe(gulp.dest("./build/models"));
});
//js task - combines and minimizes js files in /scripts directory
gulp.task("js", function() {
return gulp.src(['js/*.js','!js/_*.js'])
.pipe(include({includePaths: ['js']})).on('error', console.log)
//.pipe(sourcemaps.init())
.pipe(liveOnly(uglify({compress: {drop_console: true }}))).on('error', console.log)
//.pipe(sourcemaps.write('./maps'))
.pipe(gulp.dest("./build/js"));
});
//css task - processes sass and minimizes scss files in /sass directory
gulp.task("css", function() {
return gulp.src(['css/*.scss','!css/_*.scss'])
.pipe(sourcemaps.init())
.pipe(sass({outputStyle: cssStyle}).on('error', sass.logError))
.pipe(sourcemaps.write('maps'))
.pipe(gulp.dest("./build/css"));
});
//img project task - minimizes gif,png,jpg,svg files for projects - in /img
gulp.task("image", function() {
return gulp.src('images/**/*.*')
//minify
.pipe(imagemin())
//out
.pipe(gulp.dest('build/images'));
});
//img project task - minimizes gif,png,jpg,svg files for projects - in /img
gulp.task("thumbnails", function(done) {
generateThumbnails(done);
});
//████████████████████████████████████████████████████████████████████████████████
//████████████████████████████████ WATCHER / MASTER ██████████████████████████████
//████████████████████████████████████████████████████████████████████████████████
//the one task to rule them all
gulp.task('default',
gulp.series(
'html',
'favicon',
'models',
'css',
'image',
'js',
'thumbnails'
)
);
//start watchers
gulp.task('watch', function(){
console.log('\n███ STARTING WATCH ██████████████████████\n\n');
//watch scripts folder for changes in any files
gulp.watch(['html/*.htm'], gulp.series('html'));
//watch scripts folder for changes in any files
gulp.watch(['design/favicon.ico'], gulp.series('favicon'));
//watch scripts folder for changes in any files
gulp.watch(['models/*.glb'], gulp.series('models'));
//watch scripts folder for changes in any files
gulp.watch(['js/**/*.js*'], gulp.series('js'));
//watch sass folder for changes in any files
gulp.watch(['css/**/*.scss'], gulp.series('css'));
//watch image folder for changes in any files
gulp.watch(['images/**/*.*'], gulp.series('image'));
//watch example file for changes
gulp.watch(['examples.json'], gulp.series('js','thumbnails'));
});
/*global done*/