Nuxt/packages/server/src/middleware/modern.js

46 lines
1.3 KiB
JavaScript
Raw Normal View History

import chalk from 'chalk'
import consola from 'consola'
import { ModernBrowsers } from '@nuxt/common'
import { matchesUA } from 'browserslist-useragent'
const modernBrowsers = Object.keys(ModernBrowsers)
.map(browser => `${browser} >= ${ModernBrowsers[browser]}`)
const isModernBrowser = (ua) => {
return Boolean(ua) && matchesUA(ua, {
allowHigherVersions: true,
browsers: modernBrowsers
})
}
let detected = false
const detectModernBuild = ({ options, resources }) => {
if (detected === false && ![false, 'client', 'server'].includes(options.modern)) {
detected = true
if (resources.modernManifest) {
options.modern = options.render.ssr ? 'server' : 'client'
consola.info(`Modern bundles are detected. Modern mode (${chalk.green.bold(options.modern)}) is enabled now.`)
} else {
options.modern = false
}
}
}
const detectModernBrowser = (req, options) => {
if (options.modern === 'server') {
const { socket = {}, headers } = req
if (socket.modernMode === undefined) {
const ua = headers && headers['user-agent']
socket.modernMode = isModernBrowser(ua)
}
req.modernMode = socket.modernMode
}
}
export default ({ context }) => (req, res, next) => {
detectModernBuild(context)
detectModernBrowser(req, context.options)
next()
}