584d842ae0
Similar to https://github.com/vercel/next.js/pull/42106. Make `@next/font` works as expected when using `transpilePackages`. Also makes sure `@next/font` is auto-configured correctly when in a monorepo. ## Bug - [ ] Related issues linked using `fixes #number` - [ ] Integration tests added - [ ] Errors have a helpful link attached, see `contributing.md` ## Feature - [ ] Implements an existing feature request or RFC. Make sure the feature request has been accepted for implementation before opening a PR. - [ ] Related issues linked using `fixes #number` - [ ] Integration tests added - [ ] Documentation added - [ ] Telemetry added. In case of a feature if it's used or not. - [ ] Errors have a helpful link attached, see `contributing.md` ## Documentation / Examples - [ ] Make sure the linting passes by running `pnpm build && pnpm lint` - [ ] The "examples guidelines" are followed from [our contributing doc](https://github.com/vercel/next.js/blob/canary/contributing/examples/adding-examples.md) Co-authored-by: JJ Kasper <jj@jjsweb.site>
23 lines
823 B
TypeScript
23 lines
823 B
TypeScript
import { NodePath, PluginObj, types } from 'next/dist/compiled/babel/core'
|
|
|
|
export default function NextPageDisallowReExportAllExports(): PluginObj<any> {
|
|
return {
|
|
visitor: {
|
|
ImportDeclaration(path: NodePath<types.ImportDeclaration>) {
|
|
if (
|
|
['@next/font/local', '@next/font/google'].includes(
|
|
path.node.source.value
|
|
)
|
|
) {
|
|
const err = new SyntaxError(
|
|
`"@next/font" requires SWC although Babel is being used due to a custom babel config being present.\nRead more: https://nextjs.org/docs/messages/babel-font-loader-conflict`
|
|
)
|
|
;(err as any).code = 'BABEL_PARSE_ERROR'
|
|
;(err as any).loc =
|
|
path.node.loc?.start ?? path.node.loc?.end ?? path.node.loc
|
|
throw err
|
|
}
|
|
},
|
|
},
|
|
}
|
|
}
|