Files
next.js/packages/next-mdx/mdx-js-loader.js
Arian Tron 61f56f997c
Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
first commit
2026-03-10 19:37:31 +03:30

79 lines
2.2 KiB
JavaScript

const mdxLoader = require('@mdx-js/loader')
const { pathToFileURL } = require('node:url')
function interopDefault(mod) {
return mod.default || mod
}
async function importPluginForPath(pluginPath, projectRoot) {
const path = require.resolve(pluginPath, { paths: [projectRoot] })
return interopDefault(
// "use pathToFileUrl to make esm import()s work with absolute windows paths":
// on windows import("C:\\path\\to\\file") is not valid, so we need to use file:// URLs
// https://github.com/vercel/next.js/commit/fbf9e12de095e0237d4ba4aa6139d9757bd20be9
await import(process.platform === 'win32' ? pathToFileURL(path) : path)
)
}
async function importPlugin(plugin, projectRoot) {
if (Array.isArray(plugin) && typeof plugin[0] === 'string') {
plugin[0] = await importPluginForPath(plugin[0], projectRoot)
}
if (typeof plugin === 'string') {
plugin = await importPluginForPath(plugin, projectRoot)
}
return plugin
}
async function getOptions(options, projectRoot) {
const {
recmaPlugins = [],
rehypePlugins = [],
remarkPlugins = [],
...rest
} = options
const [updatedRecma, updatedRehype, updatedRemark] = await Promise.all([
Promise.all(
recmaPlugins.map((plugin) => importPlugin(plugin, projectRoot))
),
Promise.all(
rehypePlugins.map((plugin) => importPlugin(plugin, projectRoot))
),
Promise.all(
remarkPlugins.map((plugin) => importPlugin(plugin, projectRoot))
),
])
return {
...rest,
recmaPlugins: updatedRecma,
rehypePlugins: updatedRehype,
remarkPlugins: updatedRemark,
}
}
module.exports = function nextMdxLoader(...args) {
const options = this.getOptions()
const callback = this.async().bind(this)
const loaderContext = this
getOptions(options, this.context).then((userProvidedMdxOptions) => {
const proxy = new Proxy(loaderContext, {
get(target, prop, receiver) {
if (prop === 'getOptions') {
return () => userProvidedMdxOptions
}
if (prop === 'async') {
return () => callback
}
return Reflect.get(target, prop, receiver)
},
})
mdxLoader.call(proxy, ...args)
})
}