diff --git a/packages/website/src/components/SidebarLayout.tsx b/packages/website/src/components/SidebarLayout.tsx index c7a47ab5a..84bd1a8bb 100644 --- a/packages/website/src/components/SidebarLayout.tsx +++ b/packages/website/src/components/SidebarLayout.tsx @@ -72,18 +72,33 @@ export function SidebarLayout({ setAsPathWithoutQueryAndAnchor(router.asPath.split('?')[0]?.split('#')[0]?.split(':')[0] ?? ''); }, [router.asPath]); - const packageMenuItems = PACKAGES.map((pkg) => ( - - packageMenu.setOpen(false)} - > - {pkg} - - - )); + const packageMenuItems = useMemo( + () => [ + + packageMenu.setOpen(false)} + > + discord.js + + , + ...PACKAGES.map((pkg) => ( + + packageMenu.setOpen(false)} + > + {pkg} + + + )), + ], + // eslint-disable-next-line react-hooks/exhaustive-deps + [], + ); const versionMenuItems = useMemo( () => diff --git a/packages/website/src/middleware.ts b/packages/website/src/middleware.ts index 4139000e9..7bee8f55e 100644 --- a/packages/website/src/middleware.ts +++ b/packages/website/src/middleware.ts @@ -2,6 +2,10 @@ import { NextResponse, type NextRequest } from 'next/server'; import { PACKAGES } from './util/constants'; export default async function middleware(request: NextRequest) { + if (request.nextUrl.pathname.includes('discord.js')) { + return NextResponse.redirect('https://discord.js.org/#/docs/discord.js'); + } + if (PACKAGES.some((pkg) => request.nextUrl.pathname.includes(pkg))) { const packageName = /\/docs\/packages\/([^/]+)\/.*/.exec(request.nextUrl.pathname)?.[1] ?? 'builders'; const res = await fetch(`https://docs.discordjs.dev/api/info?package=${packageName}`); @@ -17,5 +21,5 @@ export default async function middleware(request: NextRequest) { } export const config = { - matcher: ['/docs', '/docs/packages/:package/stable/:member*'], + matcher: ['/docs', '/docs/packages/discord.js(.*)?', '/docs/packages/:package/stable/:member*'], }; diff --git a/packages/website/src/pages/docs/packages/index.tsx b/packages/website/src/pages/docs/packages/index.tsx index 459facc74..991a94cd8 100644 --- a/packages/website/src/pages/docs/packages/index.tsx +++ b/packages/website/src/pages/docs/packages/index.tsx @@ -62,6 +62,20 @@ export default function PackagesRoute(props: Partial & { error?: s

Select a package:

+ +
+
+
+ +

discord.js

+
+
+ +
+
{PACKAGES.map((pkg) => (