generate guide links at build time
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
import clsx from "clsx"
|
import clsx from "clsx"
|
||||||
import { guideLinks } from "../data/guide-links"
|
import { guideLinks } from "../data/guide-links.preval"
|
||||||
import { useScrolled } from "../hooks/dom/use-scrolled"
|
import { useScrolled } from "../hooks/dom/use-scrolled"
|
||||||
import {
|
import {
|
||||||
docsProseClass,
|
docsProseClass,
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import { AppLink } from "../components/app-link"
|
import { AppLink } from "../components/app-link"
|
||||||
import { guideLinks } from "../data/guide-links"
|
import { guideLinks } from "../data/guide-links.preval"
|
||||||
import { mainLinks } from "../data/main-links"
|
import { mainLinks } from "../data/main-links"
|
||||||
import { linkClass } from "../styles/components"
|
import { linkClass } from "../styles/components"
|
||||||
import { PopoverMenu } from "./popover-menu"
|
import { PopoverMenu } from "./popover-menu"
|
||||||
|
|||||||
34
packages/docs-new/src/data/guide-links.preval.tsx
Normal file
34
packages/docs-new/src/data/guide-links.preval.tsx
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import glob from "fast-glob"
|
||||||
|
import grayMatter from "gray-matter"
|
||||||
|
import { readFile } from "node:fs/promises"
|
||||||
|
import { join } from "node:path"
|
||||||
|
import type { AppLinkProps } from "../components/app-link"
|
||||||
|
|
||||||
|
const docsFolderPath = new URL("../docs", import.meta.url).pathname
|
||||||
|
const guideFiles = await glob("**/*.md", { cwd: docsFolderPath })
|
||||||
|
|
||||||
|
const entries = await Promise.all(
|
||||||
|
guideFiles.map(async (file) => {
|
||||||
|
const content = await readFile(join(docsFolderPath, file), "utf-8")
|
||||||
|
const { data } = grayMatter(content)
|
||||||
|
|
||||||
|
let order = Number(data.order)
|
||||||
|
if (!Number.isFinite(order)) {
|
||||||
|
order = Number.POSITIVE_INFINITY
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
route: `/docs/${file.replace(/\.mdx?$/, "")}`,
|
||||||
|
title: String(data.title || ""),
|
||||||
|
order,
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
|
||||||
|
export const guideLinks: AppLinkProps[] = entries
|
||||||
|
.sort((a, b) => a.order - b.order)
|
||||||
|
.map((item) => ({
|
||||||
|
type: "internal",
|
||||||
|
label: item.title,
|
||||||
|
to: item.route,
|
||||||
|
}))
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
import type { AppLinkProps } from "../components/app-link"
|
|
||||||
|
|
||||||
export const guideLinks: AppLinkProps[] = []
|
|
||||||
Reference in New Issue
Block a user