@vitbokisch/next-optimized-images
Version:
Automatically optimize images used in next.js projects (jpeg, png, gif, svg).
68 lines (60 loc) • 1.69 kB
JavaScript
import path from 'path'
import { createRequire } from 'module'
import { getFileLoaderOptions } from './file-loader.js'
const require = createRequire(import.meta.url)
/**
* Build options for the webpack responsive loader
*
* @param {object} nextConfig - next.js configuration
* @param {object} detectedLoaders - all detected and installed loaders
* @returns {object}
*/
const getResponsiveLoaderOptions = (
{ responsive, ...nextConfig },
isServer,
detectedLoaders
) => {
let adapter = responsive ? responsive.adapter : undefined
if (!adapter && detectedLoaders.responsiveAdapter === 'sharp') {
adapter = require(`${detectedLoaders.responsive}${path.sep}sharp`) // eslint-disable-line
}
return {
...getFileLoaderOptions(nextConfig, isServer),
name: '[name]-[width]-[hash].[ext]',
...(responsive || {}),
adapter,
}
}
/**
* Apply the responsive loader to the webpack configuration
*
* @param {object} webpackConfig - webpack configuration
* @param {object} nextConfig - next.js configuration
* @param {boolean} isServer - if the build is for the server
* @param {object} detectedLoaders - all detected and installed loaders
* @returns {object}
*/
const applyResponsiveLoader = (
webpackConfig,
nextConfig,
isServer,
detectedLoaders
) => {
webpackConfig.module.rules.push({
test: /\.(jpe?g|png)$/i,
oneOf: [
{
use: {
loader: 'responsive-loader',
options: getResponsiveLoaderOptions(
nextConfig,
isServer,
detectedLoaders
),
},
},
],
})
return webpackConfig
}
export { getResponsiveLoaderOptions, applyResponsiveLoader }