Skip to content

Commit

Permalink
meta: fix CJS interop in Vite config (#3543)
Browse files Browse the repository at this point in the history
* meta: fix CJS interop in Vite config

* fixup! meta: fix CJS interop in Vite config
  • Loading branch information
aduh95 authored Mar 8, 2022
1 parent 7b74148 commit 994acff
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 3 deletions.
1 change: 1 addition & 0 deletions private/dev/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
"devDependencies": {
"@babel/core": "^7.4.4",
"@babel/plugin-transform-react-jsx": "^7.10.4",
"@babel/types": "^7.17.0",
"autoprefixer": "^10.2.6",
"babel-plugin-transform-commonjs": "1.1.6",
"postcss-dir-pseudo-class": "^5.0.0",
Expand Down
68 changes: 65 additions & 3 deletions private/dev/vite.config.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { fileURLToPath } from 'node:url'
import { createRequire } from 'node:module'
import { transformAsync } from '@babel/core'
import t from '@babel/types'
import autoprefixer from 'autoprefixer'
import postcssLogical from 'postcss-logical'
import postcssDirPseudoClass from 'postcss-dir-pseudo-class'
Expand All @@ -26,6 +27,21 @@ function isTypeModule (file) {
moduleTypeCache.set(packageFolder, typeModule)
return typeModule
}
const packageLibImport = /^@uppy\/([^/])\/lib\/(.+)$/
const packageEntryImport = /^@uppy\/([^/])$/
function isSpecifierTypeModule (specifier) {
const packageLib = packageLibImport.exec(specifier)
if (packageLib != null) {
return isTypeModule(`${PACKAGES_ROOT}@uppy/${packageLib[1]}/src/${packageLib[2]}`)
}
const packageEntry = packageEntryImport.exec(specifier)
if (packageEntry != null) {
return isTypeModule(`${PACKAGES_ROOT}@uppy/${packageEntry[1]}/src/index.js`)
}
return false
}

const JS_FILE_EXTENSION = /\.jsx?$/

/**
* @type {import('vite').UserConfig}
Expand Down Expand Up @@ -78,7 +94,7 @@ const config = {
enforce: 'pre',
// eslint-disable-next-line consistent-return
resolveId (id) {
if (id.startsWith(PACKAGES_ROOT) && id.endsWith('.js') && !isTypeModule(id)) {
if (id.startsWith(PACKAGES_ROOT) && JS_FILE_EXTENSION.test(id)) {
return id
}
// TODO: remove this hack when we get rid of JSX inside .js files.
Expand All @@ -87,8 +103,54 @@ const config = {
}
},
transform (code, id) {
if (id.startsWith(PACKAGES_ROOT) && id.endsWith('.js') && !isTypeModule(id)) {
return transformAsync(code, {
if (id.startsWith(PACKAGES_ROOT) && JS_FILE_EXTENSION.test(id)) {
return transformAsync(code, isTypeModule(id) ? {
plugins: [
id.endsWith('.jsx') ? ['@babel/plugin-transform-react-jsx', { pragma: 'h' }] : {},
{
// On type: "module" packages, we still want to rewrite import
// statements that tries to access a named export from a CJS
// module to using only the default import.
visitor: {
ImportDeclaration (path) {
const { specifiers, source: { value } } = path.node
if (value.startsWith('@uppy/') && !isSpecifierTypeModule(value)
&& specifiers.some(node => node.type !== 'ImportDefaultSpecifier')) {
const oldSpecifiers = specifiers[0].type === 'ImportDefaultSpecifier'
// If there's a default import, it must come first.
? specifiers.splice(1)
// If there's no default import, we create one from a random identifier.
: specifiers.splice(0, specifiers.length, t.importDefaultSpecifier(t.identifier(`_import_${counter++}`)))
if (oldSpecifiers[0].type === 'ImportNamespaceSpecifier') {
// import defaultVal, * as namespaceImport from '@uppy/package'
// is transformed into:
// import defaultVal from '@uppy/package'; const namespaceImport = defaultVal
path.insertAfter(
t.variableDeclaration('const', [t.variableDeclarator(
oldSpecifiers[0].local,
specifiers[0].local,
)]),
)
} else {
// import defaultVal, { exportedVal as importedName, other } from '@uppy/package'
// is transformed into:
// import defaultVal from '@uppy/package'; const { exportedVal: importedName, other } = defaultVal
path.insertAfter(t.variableDeclaration('const', [t.variableDeclarator(
t.objectPattern(
oldSpecifiers.map(specifier => t.objectProperty(
t.identifier(specifier.imported.name),
specifier.local,
)),
),
specifiers[0].local,
)]))
}
}
},
},
},
],
} : {
plugins: [
['@babel/plugin-transform-react-jsx', { pragma: 'h' }],
'transform-commonjs',
Expand Down
1 change: 1 addition & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -10009,6 +10009,7 @@ __metadata:
dependencies:
"@babel/core": ^7.4.4
"@babel/plugin-transform-react-jsx": ^7.10.4
"@babel/types": ^7.17.0
"@uppy/companion": "workspace:^"
autoprefixer: ^10.2.6
babel-plugin-transform-commonjs: 1.1.6
Expand Down

0 comments on commit 994acff

Please sign in to comment.