-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulpfile.js
348 lines (310 loc) · 13.3 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
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
/* Gulp File
Last Modified by: Jacob Caccamo
July 20, 2021
*/
const gulp = require('gulp');
const browserSync = require('browser-sync').create();
const del = require('del');
const sassGlob = require('gulp-sass-glob');
const sourcemaps = require('gulp-sourcemaps');
const argv = require('yargs').argv;
const sass = require('gulp-sass')(require('sass'));
const autoprefixer = require('gulp-autoprefixer');
const babel = require('gulp-babel');
const concat = require('gulp-concat');
const gulpif = require('gulp-if');
const htmlreplace = require('gulp-html-replace');
const minify = require('gulp-minify');
const exec = require('child_process').exec;
const rename = require('gulp-rename');
const replace = require('gulp-replace');
const tap = require('gulp-tap');
const fs = require("fs");
let isProduction = (argv.production === undefined) ? false : true;
let createSourcemaps = false;
let pathToNDSSubmodule = "./";
// Do Not Change srcPath Variable:
let srcPath = pathToNDSSubmodule + "niaid-design-system/";
// Change to "fontawesome-pro" if you have access.
let fontAwesome = "fontawesome-free";
// compileSass - Compile CSS for your static site.
gulp.task('compileSass', () => {
console.log("Compiling Sass...");
return gulp.src('src/css/style.scss')
.pipe(sassGlob())
.pipe(concat('nds.css'))
.pipe(rename({
basename: 'nds-min',
extname: '.css'
}))
.pipe(sourcemaps.init())
.pipe(sass({
outputStyle: 'compressed',
includePaths: ["./node_modules/bootstrap/scss", "./node_modules/font-awesome/scss"]
}).on('error', sass.logError))
.pipe(autoprefixer())
.pipe(gulpif(createSourcemaps, sourcemaps.write('./maps')))
.pipe(gulp.dest('./src/css'));
});
// compileJS - Compile JS for your static site.
// This logic replaces any scripts on build in the 00-nds folder with scripts of the same name in the custom directories (01-atoms, etc.).
var includedJS = ['./src/js/utilities/utilities.js', './src/js/global/init.js'];
gulp.task('computeIncludedJSFiles', function() {
var overridesJS = [];
return gulp.src('./src/_patterns/**/*.js').pipe(tap(function(file, t) {
if (file.path.split('src/').length > 1) {
var parsedPath = file.path.split('src/')[1];
}
else {
var parsedPath = file.path.split("src\\")[1];
}
if (!parsedPath.includes('00-nds')) {
overridesJS.push(parsedPath);
includedJS.push('./src/' + parsedPath);
}
else {
var include = true;
for (var i = 0; i < overridesJS.length; i++) {
console.log(overridesJS[i].split('_patterns')[1]);
if (parsedPath.includes(overridesJS[i].split('_patterns')[1])) {
include = false;
}
}
if (include) {
console.log("Including");
includedJS.push('./src/' + parsedPath);
}
}
}));
});
gulp.task('compileJS', () => {
console.log(includedJS);
console.log("Compiling JS...");
return gulp.src(includedJS, {base: './src/'})
.pipe(concat('nds.js'))
.pipe(babel({
presets: ['@babel/env']
}))
.pipe(minify())
.pipe(sourcemaps.init())
.pipe(gulpif(createSourcemaps, sourcemaps.write('./maps')))
.pipe(gulp.dest('./src/js/'));
});
// GULP: compilePatternLab - Compile Pattern Lab for your static site.
gulp.task('compilePatternLab', (cb) => {
console.log("Compiling Pattern Lab...")
return exec('npm run build', function(err, stdout, stderr) {
browserSync.reload();
cb(err);
});
});
// GULP: computePaths - Creates distribution paths based on page name and location.
var pages = [];
gulp.task('computePaths', () => {
pages = [];
return gulp.src('./src/_patterns/05-pages/**/*.twig').pipe(tap(function(file, t) {
if (file.path.split('src/').length > 1) {
addPage(file.path);
}
else {
let escaped = file.path.replace(/\\/g, "/");
addPage(escaped);
}
}));
});
// cleanDistributionDirectories - Cleans out any distribution items before a fresh build is created.
gulp.task('cleanDistributionDirectories', (cb) => {
let dirs = [
'./dist/**/*'
];
return del(dirs, {'force': true}, cb);
});
// GULP: moveAssets - Move all distribution assets to the dist/ folder.
gulp.task('moveAssets', () => {
// Move HTML to Proper Positions
for (let i = 0; i < pages.length; i++) {
// Build Relative Path
let relativePath = ""; if (pages[i].depth === 0) { relativePath = "./"; } else { for (let j = 0; j < pages[i].depth; j++) { relativePath += "../"; }}
if (pages[i].targetPath === "/") {
var path = "./public/patterns/pages-index/pages-index.html";
gulp.src(path)
.pipe(rename({ basename: 'index', extname: '.html' }))
.pipe(replace('../../css', relativePath + 'css'))
.pipe(replace('../../js', relativePath + 'js'))
.pipe(replace('../../images', relativePath + 'assets'))
.pipe(replace('../../assets', relativePath + 'assets'))
.pipe(htmlreplace({ remove : '' }))
.pipe(gulp.dest('./dist/'));
}
else {
let depthOne = pages[i].patternLabPath + "-" + pages[i].pageName;
let deeperThanOne = pages[i].targetPath.split('/')[0] + "-" + pages[i].pageName;
var path = "./public/patterns/pages-" + (pages[i].depth > 1 ? deeperThanOne : depthOne) + "/pages-" + (pages[i].depth > 1 ? deeperThanOne : depthOne) + ".html";
gulp.src(path)
.pipe(rename({ basename: 'index', extname: '.html' }))
.pipe(replace('../../css', relativePath + 'css'))
.pipe(replace('../../js', relativePath + 'js'))
.pipe(replace('../../images', relativePath + 'assets'))
.pipe(replace('../../assets', relativePath + 'assets'))
.pipe(htmlreplace({ remove : '' }))
.pipe(gulp.dest('./dist/' + pages[i].targetPath));
}
}
// Copy CSS
console.log("Copy CSS");
gulp.src('./src/css/nds-min.css')
.pipe(gulp.dest('./dist/css'));
gulp.src('./src/css/libraries/**/*')
.pipe(gulp.dest('./dist/css/libraries'));
if (!isProduction) {
gulp.src('./src/css/maps/**/*')
.pipe(gulp.dest('./dist/css/maps'));
}
// Copy JS
console.log("Copy JS");
if (isProduction) {
gulp.src(['./src/js/**/*', '!./src/js/maps', '!./src/js/maps/**'])
.pipe(gulp.dest('./dist/js'));
}
else {
gulp.src('./src/js/**/*')
.pipe(gulp.dest('./dist/js'));
}
// Copy Images
console.log("Copy Images");
gulp.src('./src/images/**/*')
.pipe(gulp.dest('./dist/assets'));
// Copy Fonts
console.log("Copy Fonts");
return gulp.src('./src/webfonts/**/*')
.pipe(gulp.dest('./dist/webfonts'));
});
// GULP: cleanNDSSource - Cleans out any gitignored directories before fresh copies from Global Assets are added.
gulp.task('cleanNDSSource', (cb) => {
let dirs = [
'./src/_patterns/00-nds/**/*',
'./src/css/global/**/*',
'./src/css/libraries/**/*',
'./src/images/global/**/*',
'./src/js/libraries/**/*',
'./src/js/utilities/**/*',
'./src/webfonts/font-awesome/**/*',
'./src/webfonts/martel/**/*',
'./src/webfonts/merriweather/**/*',
'./src/webfonts/public-sans/**/*',
'./src/webfonts/roboto/**/*'
];
return del(dirs, {'force': true, dot: true}, cb);
});
// GULP: initializeGitSubmodule - Checks to see if NDS is installed. If not, it installs the NDS submodule.
gulp.task('initializeGitSubmodule', (cb) => {
if (!fs.existsSync(srcPath)) {
console.log("Initializing NDS Submodule");
return exec('git submodule add git@github.com:niaid/niaid-design-system.git', { cwd: pathToNDSSubmodule },
function(err, stdout, stderr) {
console.log(stdout);
cb(err);
});
}
console.log("NDS Submodule Already Installed, Skipping...")
return gulp.src('.');
});
// GULP: updateGitSubmodules - Pulls latest code for each submodule dependency.
gulp.task('updateGitSubmodules', (cb) => {
let command = 'git submodule update --init --remote ' + srcPath;
return exec(command, function(err, stdout, stderr) {
console.log(stdout);
cb(err);
});
});
// copyFontAwesome - Copy Font Awesome from node_modules into project.
gulp.task('copyFontAwesome', () => {
return gulp.src('./node_modules/@fortawesome/' + fontAwesome + '/webfonts/*')
.pipe(gulp.dest('./src/webfonts/font-awesome'));
});
// GULP: copyGlobalSass - Copy CSS into Project
gulp.task('copyGlobalSass', () => {
console.log("Transferring Assets from Global SASS...");
if (!fs.existsSync('./src/css/style.scss')) {
gulp.src(srcPath + 'src/css/style.scss').pipe(gulp.dest('./src/css/'));
}
if (!fs.existsSync('./src/css/overrides/')) {
gulp.src(srcPath + 'src/css/overrides/**/*').pipe(gulp.dest('./src/css/overrides/'));
}
gulp.src(srcPath + 'src/css/libraries/**/*').pipe(gulp.dest('./src/css/libraries/'));
return gulp.src(srcPath + 'src/css/global/**/*').pipe(gulp.dest('./src/css/global/'));
});
// GULP: copyGlobalJS - Copy JS into Project
gulp.task('copyGlobalJS', () => {
console.log("Transferring Assets from Global JS...");
if (!fs.existsSync('./src/js/global/')) {
gulp.src(srcPath + 'src/js/global/**/*').pipe(gulp.dest('./src/js/global/'));
}
gulp.src(srcPath + 'src/js/libraries/**/*').pipe(gulp.dest('./src/js/libraries/'));
return gulp.src(srcPath + 'src/js/utilities/**/*').pipe(gulp.dest('./src/js/utilities/'));
});
// GULP: copyGlobalPatterns - Copy Patterns into Project
gulp.task('copyGlobalPatterns', () => {
console.log("Transferring Assets from Global Patterns...");
console.log("Copying Patterns...");
return gulp.src(srcPath + 'src/_patterns/00-nds/**/*').pipe(gulp.dest('./src/_patterns/00-nds/'));
});
// GULP: copyGlobalImages - Copy Images into Project
gulp.task('copyGlobalImages', () => {
console.log("Transferring Assets from Global Images...");
return gulp.src(srcPath + 'src/images/**/*').pipe(gulp.dest('./src/images/'));
});
// GULP: copyGlobalFonts - Copy Fonts into NDS Drupal Theme
gulp.task('copyGlobalFonts', () => {
console.log("Transferring Assets from Global Fonts...");
gulp.src(srcPath + 'src/webfonts/martel/*').pipe(gulp.dest('./src/webfonts/martel/'));
gulp.src(srcPath + 'src/webfonts/merriweather/*').pipe(gulp.dest('./src/webfonts/merriweather/'));
gulp.src(srcPath + 'src/webfonts/roboto/*').pipe(gulp.dest('./src/webfonts/roboto/'));
return gulp.src(srcPath + 'src/webfonts/public-sans/*').pipe(gulp.dest('./src/webfonts/public-sans/'));
});
// GULP: serveProject - Serves project locally and watches files for changes.
gulp.task('serveProject', function() {
browserSync.init({
server: {
baseDir: './',
},
startPath: './public/',
open: true
});
gulp.watch(['./src/_patterns/**/*', './src/css/**/*.scss'], gulp.series('compile'));
});
// GULP AGGREGATES
// GULP: transfer - Transfers official NDS assets to appropriate locations.
gulp.task('transfer', gulp.series('copyFontAwesome', 'copyGlobalFonts', 'copyGlobalImages', 'copyGlobalSass', 'copyGlobalJS', 'copyGlobalPatterns'));
// GULP: compile - Compiles the local project assets.
gulp.task('compile', gulp.series('compileSass', 'computeIncludedJSFiles', 'compileJS', 'compilePatternLab'));
// GULP: clean - Clean out any necessary directories before building.
gulp.task('clean', gulp.series('cleanDistributionDirectories'));
// COMMANDS
// GULP: default - Running gulp compiles the your static site and serves it locally.
gulp.task('default', gulp.series('compile', 'serveProject'));
// GULP: build - Compile your project assets and build dist folder for deploy.
gulp.task('build', gulp.series('clean', 'compile', 'computePaths', 'moveAssets'));
// GULP: init - Initializes the NDS Project.
gulp.task('init', gulp.series('initializeGitSubmodule', 'updateGitSubmodules', 'transfer'));
// GULP: update - Update to the latest release of NDS. Warning: This will overwrite files in the _patterns/00-nds/ directory, as well as the global/ and libraries/ folders of css/ and js/
gulp.task('update', gulp.series('cleanNDSSource', 'initializeGitSubmodule', 'updateGitSubmodules', 'transfer'));
// HELPER FUNCTIONS
// addPage - Helper function for the computePaths() function. Determines the path and destination of the page.
function addPage(file) {
let targetPath, patternLabPath;
let distPath = file.split('src/_patterns/05-pages/')[1];
let depth = distPath.split("/").length - 1;
let pageName = distPath.split('/');
pageName = pageName[pageName.length - 1];
pageName = pageName.split('.twig')[0];
if (distPath === "index.twig") {
targetPath = "/";
patternLabPath = targetPath;
} else {
targetPath = distPath.split('/' + pageName + '.twig')[0];
patternLabPath = targetPath.replace(/\//g, '-');
};
pages.push({ "depth": depth, "pageName": pageName, "patternLabPath": patternLabPath, "targetPath": targetPath });
return;
}