mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-27 08:02:01 +00:00
119 lines
3.1 KiB
JavaScript
119 lines
3.1 KiB
JavaScript
const path = require('path')
|
|
|
|
const defaultPolyfills = [
|
|
// Promise polyfill alone doesn't work in IE,
|
|
// Needs this as well. see: #1642
|
|
'es.array.iterator',
|
|
// This is required for webpack code splitting, vuex etc.
|
|
'es.promise',
|
|
// this is needed for object rest spread support in templates
|
|
// as vue-template-es2015-compiler 1.8+ compiles it to Object.assign() calls.
|
|
'es.object.assign',
|
|
// #2012 es.promise replaces native Promise in FF and causes missing finally
|
|
'es.promise.finally'
|
|
]
|
|
|
|
function getPolyfills(targets, includes, { ignoreBrowserslistConfig, configPath }) {
|
|
const { isPluginRequired } = require('@babel/preset-env')
|
|
const builtInsList = require('core-js-compat/data')
|
|
const getTargets = require('@babel/preset-env/lib/targets-parser').default
|
|
const builtInTargets = getTargets(targets, {
|
|
ignoreBrowserslistConfig,
|
|
configPath
|
|
})
|
|
|
|
return includes.filter(item => isPluginRequired(builtInTargets, builtInsList[item]))
|
|
}
|
|
|
|
module.exports = (context, options = {}) => {
|
|
const presets = []
|
|
const plugins = []
|
|
|
|
const modern = !!options.modern
|
|
|
|
const {
|
|
polyfills: userPolyfills,
|
|
buildTarget,
|
|
loose = false,
|
|
debug = false,
|
|
useBuiltIns = 'usage',
|
|
modules = false,
|
|
spec,
|
|
ignoreBrowserslistConfig = modern,
|
|
configPath,
|
|
include,
|
|
exclude,
|
|
shippedProposals,
|
|
forceAllTransforms,
|
|
decoratorsBeforeExport,
|
|
decoratorsLegacy
|
|
} = options
|
|
|
|
let { targets } = options
|
|
if (modern === true) {
|
|
targets = { esmodules: true }
|
|
} else if (targets === undefined && typeof buildTarget === 'string') {
|
|
targets = buildTarget === 'server' ? { node: 'current' } : { ie: 9 }
|
|
}
|
|
|
|
let polyfills
|
|
if (modern === false && useBuiltIns === 'usage' && buildTarget === 'client') {
|
|
polyfills = getPolyfills(targets, userPolyfills || defaultPolyfills, {
|
|
ignoreBrowserslistConfig,
|
|
configPath
|
|
})
|
|
plugins.push([require('./polyfills-plugin'), { polyfills }])
|
|
} else {
|
|
polyfills = []
|
|
}
|
|
|
|
const corejs = { version: 3 }
|
|
|
|
// Pass options along to babel-preset-env
|
|
presets.push([
|
|
require('@babel/preset-env'), {
|
|
spec,
|
|
loose,
|
|
debug,
|
|
modules,
|
|
targets,
|
|
useBuiltIns,
|
|
corejs,
|
|
ignoreBrowserslistConfig,
|
|
configPath,
|
|
include,
|
|
exclude: polyfills.concat(exclude || []),
|
|
shippedProposals,
|
|
forceAllTransforms
|
|
}
|
|
])
|
|
|
|
// JSX
|
|
if (options.jsx !== false) {
|
|
presets.push([require('@vue/babel-preset-jsx'), Object.assign({}, options.jsx)])
|
|
}
|
|
|
|
plugins.push(
|
|
require('@babel/plugin-syntax-dynamic-import'),
|
|
[require('@babel/plugin-proposal-decorators'), {
|
|
decoratorsBeforeExport,
|
|
legacy: decoratorsLegacy !== false
|
|
}],
|
|
[require('@babel/plugin-proposal-class-properties'), { loose }]
|
|
)
|
|
|
|
// Transform runtime, but only for helpers
|
|
plugins.push([require('@babel/plugin-transform-runtime'), {
|
|
regenerator: useBuiltIns !== 'usage',
|
|
corejs: useBuiltIns !== false ? false : corejs,
|
|
helpers: useBuiltIns === 'usage',
|
|
useESModules: true,
|
|
absoluteRuntime: path.dirname(require.resolve('@babel/runtime/package.json'))
|
|
}])
|
|
|
|
return {
|
|
presets,
|
|
plugins
|
|
}
|
|
}
|