Skip to content

Commit

Permalink
Set up Browsersync with partial rebuild support
Browse files Browse the repository at this point in the history
  • Loading branch information
colinrotherham committed Jun 23, 2023
1 parent b457c86 commit d24bb85
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 73 deletions.
53 changes: 0 additions & 53 deletions lib/metalsmith-browser-sync.js

This file was deleted.

17 changes: 15 additions & 2 deletions lib/metalsmith.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,9 @@ const titleChecker = require('./metalsmith-title-checker.js')
const navigation = require('./navigation.js') // navigation plugin
const rollup = require('./rollup') // used to build GOV.UK Frontend JavaScript

// Flag production mode (to skip plugins in development)
const isProduction = process.env.NODE_ENV !== 'development'

// Nunjucks engine options
const nunjucksOptions = {
noCache: true, // never use a cache and recompile templates each time
Expand Down Expand Up @@ -66,14 +69,19 @@ const nunjucksOptions = {
// static site generator
module.exports = metalsmith(resolve(__dirname, '../'))

// notify build starting
.use((files, metalsmith) => metalsmith.watch() &&
console.log('Metalsmith build running')
)

// source directory
.source(paths.source)

// destination directory
.destination(paths.public)

// clean destination before build
.clean(true)
// clean destination for production builds
.clean(isProduction)

// global variables used in layout files
.metadata({
Expand Down Expand Up @@ -236,5 +244,10 @@ module.exports = metalsmith(resolve(__dirname, '../'))
pattern: ['**/*.html', '!**/default/*.html']
}))

// notify build starting
.use((files, metalsmith) => metalsmith.watch() &&
console.log('Metalsmith build complete')
)

// Debug
// .use(debug())
79 changes: 61 additions & 18 deletions tasks/start.js
Original file line number Diff line number Diff line change
@@ -1,22 +1,65 @@
const { dirname, join } = require('path')

const browserSync = require('browser-sync')
const slash = require('slash')

const { paths } = require('../config') // specify paths to main working directories
const metalsmith = require('../lib/metalsmith') // configured static site generator
const browsersync = require('../lib/metalsmith-browser-sync') // setup synchronised browser testing

// setup synchronised browser testing
metalsmith.use(browsersync({
ghostMode: false, // Ghost mode tries to check the same input across examples.
open: false, // When making changes to the server, we don't want multiple windows opening.
server: paths.public, // server directory
files: [
join(paths.source, '**/*'),
join(paths.views, '**/*'),
join(dirname(require.resolve('govuk-frontend/package.json')), '**/*')
] // files to watch
}))

// build to destination directory
metalsmith.build(function (err, files) {
if (err) { throw err }
})

let bs

metalsmith

// Configure sources to watch for rebuilds
.watch([
slash(paths.source),
slash(paths.views),
slash(dirname(require.resolve('govuk-frontend/package.json')))
])

// Build to destination directory
.build((err, files) => {
if (err) {
throw err
}

if (metalsmith.watch()) {
console.log('reprocessed files', Object.keys(files).join(', '))

if (bs) {
return
}

// Setup synchronised browser testing
bs = browserSync.create()

bs.init({
// Configure output to watch for reloads
files: [
join(paths.public, 'javascripts/**/*.js'),
join(paths.public, 'stylesheets/**/*.css')
],

// Prevent browser mirroring
ghostMode: false,

// Prevent browser opening
open: false,

// Serve files from directory
server: paths.public,

// Browser paths to files being watched
serveStatic: [
{
route: '/javascripts',
dir: join(paths.public, 'javascripts')
},
{
route: '/stylesheets',
dir: join(paths.public, 'stylesheets')
}
]
})
}
})

0 comments on commit d24bb85

Please sign in to comment.