Skip to content

Instantly share code, notes, and snippets.

@selfcontained
Last active December 22, 2015 21:14
Show Gist options
  • Save selfcontained/abd6d3855bf6a709fff2 to your computer and use it in GitHub Desktop.
Save selfcontained/abd6d3855bf6a709fff2 to your computer and use it in GitHub Desktop.
Using webpack versioned image filenames for pre-rendered static html files
var path = require('path')
var BLANK_GIF = ''
// With the following loader config for images...
{
test: /\.(jpe?g|png|gif)/,
loader: 'file-loader?name=[name].[sha1:hash:hex:6].[ext]'
}
// wire up custom webpack static html plugin
compiler.plugin('emit', function (compiler, done) {
var stats = compiler
.getStats()
.toJson()
// register require handlers for images
versionImages(stats.assets)
// add static html pages to compiler assets
// ...
done()
})
function versionImages (assets) {
// match versioned filename to build original filename
var regex = /([^\.]+)\.([^\.]{6})\.(.+)$/
// create a map of original filename => versioned filename
var assetMap = assets.reduce(function (hash, asset) {
var matches = regex.exec(asset.name)
if (matches) {
hash[matches[1] + '.' + matches[3]] = asset.name
}
return hash
}, {})
// require fn to return versioned filename, or blank image data uri
function versionedImage (module, filename) {
var name = path.basename(filename)
module.exports = assetMap[name] ? '/' + assetMap[name] : BLANK_GIF
}
// Handle image requires - return the versioned filename
require.extensions['.png'] = versionedImage
require.extensions['.jpg'] = versionedImage
require.extensions['.gif'] = versionedImage
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment