diff --git a/www/apps/resources/.env.sample b/www/apps/resources/.env.sample index fe1a2ddf07..d753ff21dd 100644 --- a/www/apps/resources/.env.sample +++ b/www/apps/resources/.env.sample @@ -1,5 +1,5 @@ # ESSENTIAL FOR DEV -NEXT_PUBLIC_ENV=development +NEXT_PUBLIC_ENV=development # use production when creating a build NEXT_PUBLIC_BASE_URL=http://localhost:3000 NEXT_PUBLIC_BASE_PATH=/resources diff --git a/www/apps/resources/app/api/references/[...slug]/route.ts b/www/apps/resources/app/api/references/[...slug]/route.ts new file mode 100644 index 0000000000..75873e3625 --- /dev/null +++ b/www/apps/resources/app/api/references/[...slug]/route.ts @@ -0,0 +1,119 @@ +import { unstable_cache } from "next/cache" +import path from "path" +import fs from "fs/promises" +import mdxOptions from "@/mdx-options.mjs" +import { + typeListLinkFixerPlugin, + localLinksRehypePlugin, + workflowDiagramLinkFixerPlugin, + prerequisitesLinkFixerPlugin, + recmaInjectMdxDataPlugin, +} from "remark-rehype-plugins" +import { serialize } from "next-mdx-remote-client/serialize" + +type GetRouteProps = { + params: Promise<{ + slug: string[] + }> +} + +export async function GET(request: Request, { params }: GetRouteProps) { + const { slug } = await params + const fileData = await loadReferencesFile(slug) + + if (!fileData) { + return new Response( + JSON.stringify({ + error: { + name: "NotFound", + message: "Reference file not found", + }, + }), + { + status: 404, + headers: { + "Content-Type": "application/json", + }, + } + ) + } + + return new Response(JSON.stringify(fileData.serialized), { + status: 200, + headers: { + "Content-Type": "application/json", + }, + }) +} + +const loadReferencesFile = unstable_cache(async (slug: string[]) => { + path.join(process.cwd(), "references") + const monoRepoPath = path.resolve("..", "..", "..") + + const pathname = `/references/${slug.join("/")}` + const slugChanges = (await import("@/generated/slug-changes.mjs")).slugChanges + const filesMap = (await import("@/generated/files-map.mjs")).filesMap + const fileDetails = + slugChanges.find((f) => f.newSlug === pathname) || + filesMap.find((f) => f.pathname === pathname) + if (!fileDetails) { + return undefined + } + const fullPath = path.join(monoRepoPath, fileDetails.filePath) + + const fileContent = await fs.readFile(fullPath, "utf-8") + + const pluginOptions = { + filePath: fullPath, + basePath: process.cwd(), + } + const serialized = await serialize({ + source: fileContent, + options: { + disableImports: true, + mdxOptions: { + development: process.env.NEXT_PUBLIC_ENV === "development", + format: "mdx", + rehypePlugins: [ + ...mdxOptions.options.rehypePlugins, + [ + typeListLinkFixerPlugin, + { + ...pluginOptions, + checkLinksType: "md", + }, + ], + [ + workflowDiagramLinkFixerPlugin, + { + ...pluginOptions, + checkLinksType: "value", + }, + ], + [ + prerequisitesLinkFixerPlugin, + { + ...pluginOptions, + checkLinksType: "value", + }, + ], + [localLinksRehypePlugin, pluginOptions], + ], + remarkPlugins: [...mdxOptions.options.remarkPlugins], + recmaPlugins: [ + [ + recmaInjectMdxDataPlugin, + { isRemoteMdx: true, mode: process.env.NODE_ENV }, + ], + ], + }, + }, + }) + return { + serialized, + content: fileContent, + path: fullPath, + } +}) + +export const dynamic = "force-static" diff --git a/www/apps/resources/app/references/[...slug]/page.tsx b/www/apps/resources/app/references/[...slug]/page.tsx index 6e6989f88a..975dfb6036 100644 --- a/www/apps/resources/app/references/[...slug]/page.tsx +++ b/www/apps/resources/app/references/[...slug]/page.tsx @@ -1,21 +1,10 @@ -import { MDXRemote, MDXRemoteSerializeResult } from "next-mdx-remote/rsc" -import { serialize } from "next-mdx-remote/serialize" -import path from "path" -import { promises as fs } from "fs" -import { notFound } from "next/navigation" -import { - typeListLinkFixerPlugin, - localLinksRehypePlugin, - workflowDiagramLinkFixerPlugin, - prerequisitesLinkFixerPlugin, - recmaInjectMdxDataPlugin, -} from "remark-rehype-plugins" -import MDXComponents from "@/components/MDXComponents" -import mdxOptions from "../../../mdx-options.mjs" -import { filesMap } from "../../../generated/files-map.mjs" -import { Metadata } from "next" import { cache, Suspense } from "react" import { Loading } from "docs-ui" +import path from "path" +import fs from "fs/promises" +import { ReferenceMDX } from "../../../components/ReferenceMDX" +import { Metadata } from "next" +import { getFrontMatterFromString } from "docs-utils" type PageProps = { params: Promise<{ @@ -27,60 +16,10 @@ export default async function ReferencesPage(props: PageProps) { const params = await props.params const { slug } = params - const fileData = await loadFile(slug) - - if (!fileData) { - return notFound() - } - - const pluginOptions = { - filePath: fileData.path, - basePath: process.cwd(), - } - return ( }>
- +
) @@ -89,11 +28,10 @@ export default async function ReferencesPage(props: PageProps) { export async function generateMetadata({ params, }: PageProps): Promise { - // read route params const slug = (await params).slug const metadata: Metadata = {} - const fileData = await loadFile(slug) + const fileData = await loadReferencesFile(slug) if (!fileData) { return metadata @@ -106,28 +44,26 @@ export async function generateMetadata({ } metadata.title = pageTitleMatch.groups.title - metadata.keywords = (fileData.source.frontmatter?.keywords || []) as string[] + const frontmatter = await getFrontMatterFromString(fileData.content) + metadata.keywords = (frontmatter.keywords || []) as string[] return metadata } -const loadFile = cache( - async ( - slug: string[] - ): Promise< - | { - content: string - source: MDXRemoteSerializeResult - path: string - } - | undefined - > => { +export type LoadedReferenceFile = { + content: string + path: string +} + +const loadReferencesFile = cache( + async (slug: string[]): Promise => { path.join(process.cwd(), "references") const monoRepoPath = path.resolve("..", "..", "..") const pathname = `/references/${slug.join("/")}` - const slugChanges = (await import("../../../generated/slug-changes.mjs")) + const slugChanges = (await import("@/generated/slug-changes.mjs")) .slugChanges + const filesMap = (await import("@/generated/files-map.mjs")).filesMap const fileDetails = slugChanges.find((f) => f.newSlug === pathname) || filesMap.find((f) => f.pathname === pathname) @@ -137,12 +73,9 @@ const loadFile = cache( const fullPath = path.join(monoRepoPath, fileDetails.filePath) const fileContent = await fs.readFile(fullPath, "utf-8") - const serialized = await serialize(fileContent, { - parseFrontmatter: true, - }) + return { content: fileContent, - source: serialized, path: fullPath, } } diff --git a/www/apps/resources/components/ReferenceMDX/index.tsx b/www/apps/resources/components/ReferenceMDX/index.tsx new file mode 100644 index 0000000000..d81c957689 --- /dev/null +++ b/www/apps/resources/components/ReferenceMDX/index.tsx @@ -0,0 +1,33 @@ +"use client" + +import { MDXClientLazy, SerializeResult } from "next-mdx-remote-client/csr" +import MDXComponents from "../MDXComponents" +import { Loading, swrFetcher } from "docs-ui" +import useSWR from "swr" +import { config } from "../../config" +import { notFound } from "next/navigation" + +type ReferenceMDXProps = { + slug: string[] +} + +export const ReferenceMDX = ({ slug }: ReferenceMDXProps) => { + const { + data: serializedResult, + error, + isLoading, + } = useSWR( + `${config.basePath}/api/references/${slug.join("/")}`, + swrFetcher + ) + + if (isLoading || !serializedResult) { + return + } + + if ("error" in serializedResult || error) { + return notFound() + } + + return +} diff --git a/www/apps/resources/package.json b/www/apps/resources/package.json index 757fb94cf3..b1ba594ac4 100644 --- a/www/apps/resources/package.json +++ b/www/apps/resources/package.json @@ -22,12 +22,14 @@ "clsx": "^2.1.0", "docs-ui": "*", "next": "15.3.5", + "next-mdx-remote-client": "2", "posthog-js": "^1.269.1", "react": "rc", "react-dom": "rc", "rehype-mdx-code-props": "^2.0.0", "remark-directive": "^3.0.0", - "remark-frontmatter": "^5.0.0" + "remark-frontmatter": "^5.0.0", + "swr": "^2.3.6" }, "devDependencies": { "@next/bundle-analyzer": "^15.3.5", diff --git a/www/packages/docs-ui/src/components/CodeTabs/index.tsx b/www/packages/docs-ui/src/components/CodeTabs/index.tsx index 93ef3d4a7d..d2dee82162 100644 --- a/www/packages/docs-ui/src/components/CodeTabs/index.tsx +++ b/www/packages/docs-ui/src/components/CodeTabs/index.tsx @@ -66,17 +66,28 @@ export const CodeTabs = ({ return codeBlock.props as CodeBlockProps } - if ( - "children" in codeBlock.props && - typeof codeBlock.props.children === "object" && - codeBlock.props.children - ) { - return getCodeBlockProps( - codeBlock.props.children as React.ReactElement< - unknown, - string | React.JSXElementConstructor - > - ) + if ("children" in codeBlock.props) { + if ( + typeof codeBlock.props.children === "object" && + codeBlock.props.children + ) { + return getCodeBlockProps( + codeBlock.props.children as React.ReactElement< + unknown, + string | React.JSXElementConstructor + > + ) + } else if (typeof codeBlock.props.children === "string") { + const lang = "lang" in codeBlock.props ? codeBlock.props.lang : "ts" + return { + ...codeBlock.props, + source: codeBlock.props.children, + className: + "className" in codeBlock.props + ? codeBlock.props.className + : `language-${lang}`, + } as CodeBlockProps + } } return undefined @@ -90,7 +101,6 @@ export const CodeTabs = ({ } const typedChildProps = child.props as CodeTab if ( - !React.isValidElement(child) || !typedChildProps.label || !typedChildProps.value || !React.isValidElement(typedChildProps.children) @@ -109,11 +119,14 @@ export const CodeTabs = ({ let codeBlockProps = codeBlock.props as CodeBlockProps const showBadge = !codeBlockProps.title const originalBadgeLabel = codeBlockProps.badgeLabel + const parsedCodeBlockProps = getCodeBlockProps(codeBlock) || { + source: "", + } const commonProps = { badgeLabel: showBadge ? undefined : originalBadgeLabel, hasTabs: true, - className: clsx("!my-0", codeBlockProps.className), + className: clsx("!my-0", parsedCodeBlockProps.className), } if ( @@ -128,9 +141,7 @@ export const CodeTabs = ({ } const modifiedProps: CodeBlockProps = { - ...(getCodeBlockProps(codeBlock) || { - source: "", - }), + ...parsedCodeBlockProps, ...commonProps, } diff --git a/www/packages/docs-ui/src/hooks/index.ts b/www/packages/docs-ui/src/hooks/index.ts index eb757426df..cf8192a6a7 100644 --- a/www/packages/docs-ui/src/hooks/index.ts +++ b/www/packages/docs-ui/src/hooks/index.ts @@ -9,6 +9,7 @@ export * from "./use-generate-snippet" export * from "./use-heading-url" export * from "./use-current-learning-path" export * from "./use-is-external-link" +export * from "./use-mutation-observer" export * from "./use-keyboard-shortcut" export * from "./use-page-scroll-manager" export * from "./use-request-runner" diff --git a/www/packages/docs-ui/src/hooks/use-mutation-observer.ts b/www/packages/docs-ui/src/hooks/use-mutation-observer/index.ts similarity index 97% rename from www/packages/docs-ui/src/hooks/use-mutation-observer.ts rename to www/packages/docs-ui/src/hooks/use-mutation-observer/index.ts index 4a3cb41542..7e1aea6283 100644 --- a/www/packages/docs-ui/src/hooks/use-mutation-observer.ts +++ b/www/packages/docs-ui/src/hooks/use-mutation-observer/index.ts @@ -1,3 +1,5 @@ +"use client" + import { useEffect } from "react" type UseMutationObserverProps = { diff --git a/www/packages/docs-utils/src/get-front-matter.ts b/www/packages/docs-utils/src/get-front-matter.ts index 71e8b90186..ac17acbfde 100644 --- a/www/packages/docs-utils/src/get-front-matter.ts +++ b/www/packages/docs-utils/src/get-front-matter.ts @@ -28,3 +28,20 @@ export function getFrontMatterSync(filePath: string): FrontMatter { return content.data.matter as FrontMatter } + +export async function getFrontMatterFromString( + fileContent: string +): Promise { + return ( + await unified() + .use(remarkParse) + .use(remarkStringify) + .use(remarkFrontmatter, ["yaml"]) + .use(() => { + return (tree, file) => { + matter(file) + } + }) + .process(fileContent) + ).data.matter as FrontMatter +} diff --git a/www/packages/types/src/frontmatter.ts b/www/packages/types/src/frontmatter.ts index 0b0b402850..34389e760a 100644 --- a/www/packages/types/src/frontmatter.ts +++ b/www/packages/types/src/frontmatter.ts @@ -19,4 +19,5 @@ export declare type FrontMatter = { toc_max_depth?: number generate_toc?: boolean hide_content_menu?: boolean + keywords?: string[] } diff --git a/www/yarn.lock b/www/yarn.lock index 5804e3ff3a..d307ddab23 100644 --- a/www/yarn.lock +++ b/www/yarn.lock @@ -313,6 +313,17 @@ __metadata: languageName: node linkType: hard +"@babel/code-frame@npm:^7.27.1": + version: 7.27.1 + resolution: "@babel/code-frame@npm:7.27.1" + dependencies: + "@babel/helper-validator-identifier": ^7.27.1 + js-tokens: ^4.0.0 + picocolors: ^1.1.1 + checksum: 5dd9a18baa5fce4741ba729acc3a3272c49c25cb8736c4b18e113099520e7ef7b545a4096a26d600e4416157e63e87d66db46aa3fbf0a5f2286da2705c12da00 + languageName: node + linkType: hard + "@babel/compat-data@npm:^7.23.5": version: 7.23.5 resolution: "@babel/compat-data@npm:7.23.5" @@ -471,6 +482,13 @@ __metadata: languageName: node linkType: hard +"@babel/helper-validator-identifier@npm:^7.27.1": + version: 7.27.1 + resolution: "@babel/helper-validator-identifier@npm:7.27.1" + checksum: c558f11c4871d526498e49d07a84752d1800bf72ac0d3dad100309a2eaba24efbf56ea59af5137ff15e3a00280ebe588560534b0e894a4750f8b1411d8f78b84 + languageName: node + linkType: hard + "@babel/helper-validator-option@npm:^7.23.5": version: 7.23.5 resolution: "@babel/helper-validator-option@npm:7.23.5" @@ -1355,6 +1373,39 @@ __metadata: languageName: node linkType: hard +"@mdx-js/mdx@npm:^3.1.1": + version: 3.1.1 + resolution: "@mdx-js/mdx@npm:3.1.1" + dependencies: + "@types/estree": ^1.0.0 + "@types/estree-jsx": ^1.0.0 + "@types/hast": ^3.0.0 + "@types/mdx": ^2.0.0 + acorn: ^8.0.0 + collapse-white-space: ^2.0.0 + devlop: ^1.0.0 + estree-util-is-identifier-name: ^3.0.0 + estree-util-scope: ^1.0.0 + estree-walker: ^3.0.0 + hast-util-to-jsx-runtime: ^2.0.0 + markdown-extensions: ^2.0.0 + recma-build-jsx: ^1.0.0 + recma-jsx: ^1.0.0 + recma-stringify: ^1.0.0 + rehype-recma: ^1.0.0 + remark-mdx: ^3.0.0 + remark-parse: ^11.0.0 + remark-rehype: ^11.0.0 + source-map: ^0.7.0 + unified: ^11.0.0 + unist-util-position-from-estree: ^2.0.0 + unist-util-stringify-position: ^4.0.0 + unist-util-visit: ^5.0.0 + vfile: ^6.0.0 + checksum: 371ed95e2bee7731f30a7ce57db66383a0b7470e66c38139427174cb456d6a40bf7d259f3652716370c1de64acfba50a1ba27eb8c556e7a431dc7940b04cb1a1 + languageName: node + linkType: hard + "@mdx-js/react@npm:^3.0.1": version: 3.0.1 resolution: "@mdx-js/react@npm:3.0.1" @@ -1379,6 +1430,18 @@ __metadata: languageName: node linkType: hard +"@mdx-js/react@npm:^3.1.1": + version: 3.1.1 + resolution: "@mdx-js/react@npm:3.1.1" + dependencies: + "@types/mdx": ^2.0.0 + peerDependencies: + "@types/react": ">=16" + react: ">=16" + checksum: 34ca98bc2a0f969894ea144dc5c8a5294690505458cd24965cd9be854d779c193ad9192bf9143c4c18438fafd1902e100d99067e045c69319288562d497558c6 + languageName: node + linkType: hard + "@medusajs/icons@npm:2.10.3": version: 2.10.3 resolution: "@medusajs/icons@npm:2.10.3" @@ -4926,6 +4989,15 @@ __metadata: languageName: node linkType: hard +"@types/mdast@npm:^4.0.4": + version: 4.0.4 + resolution: "@types/mdast@npm:4.0.4" + dependencies: + "@types/unist": "*" + checksum: 84f403dbe582ee508fd9c7643ac781ad8597fcbfc9ccb8d4715a2c92e4545e5772cbd0dbdf18eda65789386d81b009967fdef01b24faf6640f817287f54d9c82 + languageName: node + linkType: hard + "@types/mdx@npm:^2.0.0": version: 2.0.11 resolution: "@types/mdx@npm:2.0.11" @@ -7007,7 +7079,7 @@ __metadata: languageName: node linkType: hard -"dequal@npm:^2.0.0": +"dequal@npm:^2.0.0, dequal@npm:^2.0.3": version: 2.0.3 resolution: "dequal@npm:2.0.3" checksum: f98860cdf58b64991ae10205137c0e97d384c3a4edc7f807603887b7c4b850af1224a33d88012009f150861cbee4fa2d322c4cc04b9313bee312e47f6ecaa888 @@ -10590,7 +10662,7 @@ __metadata: languageName: node linkType: hard -"mdast-util-mdxjs-esm@npm:^2.0.0": +"mdast-util-mdxjs-esm@npm:^2.0.0, mdast-util-mdxjs-esm@npm:^2.0.1": version: 2.0.1 resolution: "mdast-util-mdxjs-esm@npm:2.0.1" dependencies: @@ -11629,6 +11701,24 @@ __metadata: languageName: node linkType: hard +"next-mdx-remote-client@npm:2": + version: 2.1.7 + resolution: "next-mdx-remote-client@npm:2.1.7" + dependencies: + "@babel/code-frame": ^7.27.1 + "@mdx-js/mdx": ^3.1.1 + "@mdx-js/react": ^3.1.1 + remark-mdx-remove-esm: ^1.2.1 + serialize-error: ^12.0.0 + vfile: ^6.0.3 + vfile-matter: ^5.0.1 + peerDependencies: + react: ^19.1 + react-dom: ^19.1 + checksum: 6d7a27e9a5068509e043cdcbadc2d93559077cdcbf2c3ee429b4cc579c7a0bbc10285f6983113f9210c65063d6118ae1ffb418d14a5e7ac810a9734046b48d3f + languageName: node + linkType: hard + "next-mdx-remote@npm:5.0.0": version: 5.0.0 resolution: "next-mdx-remote@npm:5.0.0" @@ -13134,6 +13224,19 @@ __metadata: languageName: node linkType: hard +"remark-mdx-remove-esm@npm:^1.2.1": + version: 1.2.1 + resolution: "remark-mdx-remove-esm@npm:1.2.1" + dependencies: + "@types/mdast": ^4.0.4 + mdast-util-mdxjs-esm: ^2.0.1 + unist-util-remove: ^4.0.0 + peerDependencies: + unified: ^11 + checksum: 795fceac27402fdf98273d6f917436a49012cbd5c0b8a75dfd4ac59e0e32b17ad3e89cfda4a5553a5d7e04a669c00d8017a3a15e89d5073f1da9c3eaa970eebe + languageName: node + linkType: hard + "remark-mdx@npm:^3.0.0": version: 3.0.1 resolution: "remark-mdx@npm:3.0.1" @@ -13326,6 +13429,7 @@ __metadata: eslint-plugin-prettier: ^5.2.1 eslint-plugin-react-hooks: ^5.0.0 next: 15.3.5 + next-mdx-remote-client: 2 postcss: ^8 posthog-js: ^1.269.1 react: rc @@ -13334,6 +13438,7 @@ __metadata: remark-directive: ^3.0.0 remark-frontmatter: ^5.0.0 remark-rehype-plugins: "*" + swr: ^2.3.6 tags: "*" tailwind: "*" tailwindcss: ^3.3.0 @@ -13575,6 +13680,15 @@ __metadata: languageName: node linkType: hard +"serialize-error@npm:^12.0.0": + version: 12.0.0 + resolution: "serialize-error@npm:12.0.0" + dependencies: + type-fest: ^4.31.0 + checksum: d8422db262dd28422834e0acdaaa2425ba6735f791417cfbcbceb201ddea0e41ccd2865778afeb9b33c28273f01e89a4503fa670f82c0a387de61e2b0f8d74e4 + languageName: node + linkType: hard + "set-function-length@npm:^1.2.1": version: 1.2.1 resolution: "set-function-length@npm:1.2.1" @@ -14291,6 +14405,18 @@ __metadata: languageName: node linkType: hard +"swr@npm:^2.3.6": + version: 2.3.6 + resolution: "swr@npm:2.3.6" + dependencies: + dequal: ^2.0.3 + use-sync-external-store: ^1.4.0 + peerDependencies: + react: ^16.11.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + checksum: 9534f350982e36a3ae0a13da8c0f7da7011fc979e77f306e60c4e5db0f9b84f17172c44f973441ba56bb684b69b0d9838ab40011a6b6b3e32d0cd7f3d5405f99 + languageName: node + linkType: hard + "symbol-tree@npm:^3.2.4": version: 3.2.4 resolution: "symbol-tree@npm:3.2.4" @@ -14837,6 +14963,13 @@ turbo@latest: languageName: node linkType: hard +"type-fest@npm:^4.31.0": + version: 4.41.0 + resolution: "type-fest@npm:4.41.0" + checksum: f5ca697797ed5e88d33ac8f1fec21921839871f808dc59345c9cf67345bfb958ce41bd821165dbf3ae591cedec2bf6fe8882098dfdd8dc54320b859711a2c1e4 + languageName: node + linkType: hard + "typed-array-buffer@npm:^1.0.1, typed-array-buffer@npm:^1.0.2": version: 1.0.2 resolution: "typed-array-buffer@npm:1.0.2" @@ -15243,6 +15376,17 @@ turbo@latest: languageName: node linkType: hard +"unist-util-remove@npm:^4.0.0": + version: 4.0.0 + resolution: "unist-util-remove@npm:4.0.0" + dependencies: + "@types/unist": ^3.0.0 + unist-util-is: ^6.0.0 + unist-util-visit-parents: ^6.0.0 + checksum: 30f3ed31095dd7f3109266d39c514fab5f2da3fb656d5f78a0e3e7700f219760f2f4d8286c810ae43c241fee3f0a8dd40f8d1e5ebeee3cb810581d5e7e8d4f7d + languageName: node + linkType: hard + "unist-util-stringify-position@npm:^2.0.0": version: 2.0.3 resolution: "unist-util-stringify-position@npm:2.0.3" @@ -15392,6 +15536,15 @@ turbo@latest: languageName: node linkType: hard +"use-sync-external-store@npm:^1.4.0": + version: 1.6.0 + resolution: "use-sync-external-store@npm:1.6.0" + peerDependencies: + react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + checksum: 35e1179f872a53227bdf8a827f7911da4c37c0f4091c29b76b1e32473d1670ebe7bcd880b808b7549ba9a5605c233350f800ffab963ee4a4ee346ee983b6019b + languageName: node + linkType: hard + "user-guide@workspace:apps/user-guide": version: 0.0.0-use.local resolution: "user-guide@workspace:apps/user-guide" @@ -15530,7 +15683,7 @@ turbo@latest: languageName: node linkType: hard -"vfile@npm:^6.0.1": +"vfile@npm:^6.0.1, vfile@npm:^6.0.3": version: 6.0.3 resolution: "vfile@npm:6.0.3" dependencies: