2024-08-08 14:32:33 -06:00
|
|
|
const { src, dest, series } = require('gulp');
|
|
|
|
|
const rollup = require('@rollup/stream');
|
|
|
|
|
const rollupPluginCommonjs = require('@rollup/plugin-commonjs');
|
|
|
|
|
const rollupPluginNodeResolve = require('@rollup/plugin-node-resolve');
|
|
|
|
|
const source = require('vinyl-source-stream');
|
|
|
|
|
const buffer = require('vinyl-buffer');
|
2024-08-08 14:01:05 -06:00
|
|
|
const gulpMerge = require('gulp-merge');
|
2024-09-18 13:59:16 -04:00
|
|
|
const uswds = require('@uswds/compile');
|
2024-09-26 15:01:34 -04:00
|
|
|
const { exec } = require('child_process');
|
2019-04-05 13:31:13 +01:00
|
|
|
const plugins = {};
|
|
|
|
|
plugins.addSrc = require('gulp-add-src');
|
|
|
|
|
plugins.babel = require('gulp-babel');
|
2019-11-26 14:18:57 +00:00
|
|
|
plugins.cleanCSS = require('gulp-clean-css');
|
2019-04-05 13:31:13 +01:00
|
|
|
plugins.concat = require('gulp-concat');
|
|
|
|
|
plugins.jshint = require('gulp-jshint');
|
|
|
|
|
plugins.prettyerror = require('gulp-prettyerror');
|
|
|
|
|
plugins.uglify = require('gulp-uglify');
|
2015-12-20 00:00:01 +00:00
|
|
|
|
2019-04-01 09:58:13 +01:00
|
|
|
const paths = {
|
|
|
|
|
src: 'app/assets/',
|
|
|
|
|
dist: 'app/static/',
|
|
|
|
|
npm: 'node_modules/',
|
2019-10-09 15:03:35 +01:00
|
|
|
toolkit: 'node_modules/govuk_frontend_toolkit/',
|
2024-09-18 13:59:16 -04:00
|
|
|
govuk_frontend: 'node_modules/govuk-frontend/',
|
2019-04-01 09:58:13 +01:00
|
|
|
};
|
2019-10-11 10:26:25 +01:00
|
|
|
|
2019-04-01 09:58:13 +01:00
|
|
|
const javascripts = () => {
|
2024-08-08 14:32:33 -06:00
|
|
|
const vendored = rollup({
|
|
|
|
|
input: paths.src + 'javascripts/modules/all.mjs',
|
|
|
|
|
plugins: [
|
|
|
|
|
rollupPluginNodeResolve({
|
2024-09-18 13:59:16 -04:00
|
|
|
mainFields: ['module', 'main'],
|
2024-08-08 14:32:33 -06:00
|
|
|
}),
|
|
|
|
|
rollupPluginCommonjs({
|
2024-09-18 13:59:16 -04:00
|
|
|
include: 'node_modules/**',
|
|
|
|
|
}),
|
2024-08-08 14:32:33 -06:00
|
|
|
],
|
|
|
|
|
output: {
|
|
|
|
|
format: 'iife',
|
2024-09-18 13:59:16 -04:00
|
|
|
name: 'GOVUK',
|
|
|
|
|
},
|
2024-08-08 14:32:33 -06:00
|
|
|
})
|
|
|
|
|
.pipe(source('all.mjs'))
|
|
|
|
|
.pipe(buffer())
|
2024-09-18 13:59:16 -04:00
|
|
|
.pipe(
|
|
|
|
|
plugins.addSrc.prepend([
|
|
|
|
|
paths.npm + 'jquery/dist/jquery.min.js',
|
|
|
|
|
paths.npm + 'query-command-supported/dist/queryCommandSupported.min.js',
|
|
|
|
|
paths.npm + 'textarea-caret/index.js',
|
|
|
|
|
paths.npm + 'cbor-js/cbor.js',
|
|
|
|
|
paths.npm + 'd3/dist/d3.min.js',
|
2025-05-07 11:08:03 -04:00
|
|
|
paths.npm + 'socket.io-client/dist/socket.io.min.js'
|
2024-09-18 13:59:16 -04:00
|
|
|
])
|
|
|
|
|
);
|
2019-11-20 13:43:07 +00:00
|
|
|
|
|
|
|
|
const local = src([
|
|
|
|
|
paths.toolkit + 'javascripts/govuk/modules.js',
|
|
|
|
|
paths.toolkit + 'javascripts/govuk/show-hide-content.js',
|
2021-08-27 17:32:06 +01:00
|
|
|
paths.src + 'javascripts/copyToClipboard.js',
|
2019-11-20 13:43:07 +00:00
|
|
|
paths.src + 'javascripts/enhancedTextbox.js',
|
|
|
|
|
paths.src + 'javascripts/fileUpload.js',
|
|
|
|
|
paths.src + 'javascripts/radioSelect.js',
|
|
|
|
|
paths.src + 'javascripts/updateContent.js',
|
|
|
|
|
paths.src + 'javascripts/listEntry.js',
|
|
|
|
|
paths.src + 'javascripts/liveSearch.js',
|
|
|
|
|
paths.src + 'javascripts/errorTracking.js',
|
|
|
|
|
paths.src + 'javascripts/preventDuplicateFormSubmissions.js',
|
|
|
|
|
paths.src + 'javascripts/fullscreenTable.js',
|
|
|
|
|
paths.src + 'javascripts/templateFolderForm.js',
|
|
|
|
|
paths.src + 'javascripts/collapsibleCheckboxes.js',
|
2019-12-02 18:15:00 +00:00
|
|
|
paths.src + 'javascripts/radioSlider.js',
|
2021-01-06 17:32:46 +00:00
|
|
|
paths.src + 'javascripts/updateStatus.js',
|
2021-07-20 12:14:10 +01:00
|
|
|
paths.src + 'javascripts/errorBanner.js',
|
2025-05-07 11:08:03 -04:00
|
|
|
paths.src + 'javascripts/notifyModal.js',
|
2023-09-07 08:38:41 -06:00
|
|
|
paths.src + 'javascripts/timeoutPopup.js',
|
2023-11-16 12:02:59 -05:00
|
|
|
paths.src + 'javascripts/date.js',
|
2024-02-27 11:53:51 -05:00
|
|
|
paths.src + 'javascripts/loginAlert.js',
|
2019-12-15 19:38:49 +00:00
|
|
|
paths.src + 'javascripts/main.js',
|
2024-07-18 15:27:17 -04:00
|
|
|
paths.src + 'javascripts/totalMessagesChart.js',
|
|
|
|
|
paths.src + 'javascripts/activityChart.js',
|
2025-01-09 12:00:50 -04:00
|
|
|
paths.src + 'javascripts/sidenav.js',
|
2025-02-24 12:29:58 -05:00
|
|
|
paths.src + 'javascripts/validation.js',
|
2025-03-26 12:54:21 -07:00
|
|
|
paths.src + 'javascripts/socketio.js',
|
2019-11-20 13:43:07 +00:00
|
|
|
])
|
2022-07-21 18:25:23 -07:00
|
|
|
.pipe(plugins.prettyerror())
|
2024-09-18 13:59:16 -04:00
|
|
|
.pipe(
|
|
|
|
|
plugins.babel({
|
|
|
|
|
presets: ['@babel/preset-env'],
|
|
|
|
|
})
|
|
|
|
|
);
|
2019-11-20 13:43:07 +00:00
|
|
|
|
2024-08-08 14:01:05 -06:00
|
|
|
return gulpMerge(vendored, local)
|
2019-04-01 09:58:13 +01:00
|
|
|
.pipe(plugins.uglify())
|
|
|
|
|
.pipe(plugins.concat('all.js'))
|
2024-08-08 14:32:33 -06:00
|
|
|
.pipe(dest(paths.dist + 'javascripts/'));
|
2019-04-01 09:58:13 +01:00
|
|
|
};
|
2016-09-12 16:11:34 +01:00
|
|
|
|
2024-08-09 09:41:13 -06:00
|
|
|
// Task to copy `gtm_head.js`
|
2024-08-09 09:18:50 -06:00
|
|
|
const copyGtmHead = () => {
|
2024-09-18 13:59:16 -04:00
|
|
|
return src(paths.src + 'js/gtm_head.js').pipe(dest(paths.dist + 'js/'));
|
2019-04-01 09:58:13 +01:00
|
|
|
};
|
|
|
|
|
|
2024-08-23 14:01:51 -07:00
|
|
|
// Task to copy `setTimezone.js`
|
|
|
|
|
const copySetTimezone = () => {
|
2024-09-18 13:59:16 -04:00
|
|
|
return src(paths.src + 'js/setTimezone.js').pipe(dest(paths.dist + 'js/'));
|
2024-08-23 14:01:51 -07:00
|
|
|
};
|
|
|
|
|
|
2024-08-09 09:41:13 -06:00
|
|
|
// Task to copy images
|
|
|
|
|
const copyImages = () => {
|
2024-09-18 13:59:16 -04:00
|
|
|
return src(paths.src + 'images/**/*', { encoding: false }).pipe(
|
|
|
|
|
dest(paths.dist + 'images/')
|
|
|
|
|
);
|
2019-04-01 09:58:13 +01:00
|
|
|
};
|
2016-02-08 11:05:07 +00:00
|
|
|
|
2024-10-25 11:00:51 -07:00
|
|
|
// Task to pdf files
|
2024-10-25 10:59:55 -07:00
|
|
|
const copyPDF = () => {
|
|
|
|
|
return src(paths.src + 'pdf/**/*', { encoding: false }).pipe(
|
|
|
|
|
dest(paths.dist + 'pdf/')
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
2025-05-07 11:08:03 -04:00
|
|
|
const copyUSWDSJS = () => {
|
|
|
|
|
return src('node_modules/@uswds/uswds/dist/js/uswds.min.js')
|
|
|
|
|
.pipe(dest(paths.dist + 'js/'));
|
|
|
|
|
};
|
|
|
|
|
|
2024-08-09 09:41:13 -06:00
|
|
|
// Configure USWDS paths
|
2023-04-24 14:57:35 -04:00
|
|
|
uswds.settings.version = 3;
|
2025-06-10 20:24:08 -04:00
|
|
|
uswds.settings.compile = {
|
|
|
|
|
sass: true,
|
|
|
|
|
javascript: true,
|
|
|
|
|
sprites: false
|
|
|
|
|
};
|
|
|
|
|
|
2024-08-09 07:40:58 -06:00
|
|
|
uswds.paths.dist.css = paths.dist + 'css';
|
|
|
|
|
uswds.paths.dist.js = paths.dist + 'js';
|
|
|
|
|
uswds.paths.dist.img = paths.dist + 'img';
|
2024-10-25 10:59:55 -07:00
|
|
|
uswds.paths.dist.pdf = paths.dist + 'pdf';
|
2024-08-09 07:40:58 -06:00
|
|
|
uswds.paths.dist.fonts = paths.dist + 'fonts';
|
|
|
|
|
uswds.paths.dist.theme = paths.src + 'sass/uswds';
|
|
|
|
|
|
2024-08-09 09:41:13 -06:00
|
|
|
// Task to compile USWDS styles
|
2024-08-09 07:40:58 -06:00
|
|
|
const styles = async () => {
|
2025-06-10 20:42:55 -04:00
|
|
|
await uswds.compileSass();
|
2024-08-09 07:40:58 -06:00
|
|
|
};
|
2023-04-24 14:57:35 -04:00
|
|
|
|
2025-06-10 20:42:55 -04:00
|
|
|
// Task to copy USWDS assetsconst
|
2025-06-10 20:17:57 -04:00
|
|
|
const copyUSWDSAssets = () => {
|
|
|
|
|
return src([
|
|
|
|
|
'node_modules/@uswds/uswds/dist/img/**/*',
|
|
|
|
|
'node_modules/@uswds/uswds/dist/fonts/**/*'
|
|
|
|
|
], { encoding: false })
|
2025-06-10 20:24:08 -04:00
|
|
|
.pipe(dest((file) => {
|
|
|
|
|
if (file.path.includes('/img/')) {
|
|
|
|
|
return paths.dist + 'img/';
|
|
|
|
|
} else if (file.path.includes('/fonts/')) {
|
|
|
|
|
return paths.dist + 'fonts/';
|
|
|
|
|
}
|
|
|
|
|
return paths.dist;
|
|
|
|
|
}));
|
2024-08-09 07:40:58 -06:00
|
|
|
};
|
2023-04-24 14:57:35 -04:00
|
|
|
|
2024-09-18 13:59:16 -04:00
|
|
|
// Optional backstopJS task
|
|
|
|
|
// Install gulp globally and run `gulp backstopTest`
|
|
|
|
|
const backstopTest = (done) => {
|
|
|
|
|
exec(
|
|
|
|
|
'npx backstop test --configPath=backstop.config.js',
|
|
|
|
|
(err, stdout, stderr) => {
|
|
|
|
|
console.log(stdout);
|
|
|
|
|
console.error(stderr);
|
|
|
|
|
done(err);
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Optional backstopJS reference task
|
|
|
|
|
// Install gulp globally and run `gulp backstopReference`
|
|
|
|
|
const backstopReference = (done) => {
|
|
|
|
|
exec(
|
|
|
|
|
'npx backstop reference --configPath=backstop.config.js',
|
|
|
|
|
(err, stdout, stderr) => {
|
|
|
|
|
console.log(stdout);
|
|
|
|
|
console.error(stderr);
|
|
|
|
|
done(err);
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Export tasks
|
|
|
|
|
exports.default = series(
|
|
|
|
|
styles,
|
|
|
|
|
javascripts,
|
|
|
|
|
copyGtmHead,
|
|
|
|
|
copySetTimezone,
|
|
|
|
|
copyImages,
|
2024-10-25 10:59:55 -07:00
|
|
|
copyPDF,
|
2025-06-10 20:17:57 -04:00
|
|
|
copyUSWDSAssets,
|
2025-05-07 11:08:03 -04:00
|
|
|
copyUSWDSJS
|
2024-09-18 13:59:16 -04:00
|
|
|
);
|
|
|
|
|
exports.backstopTest = backstopTest;
|
|
|
|
|
exports.backstopReference = backstopReference;
|