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) => (
-
-
-
- ));
+ const packageMenuItems = useMemo(
+ () => [
+
+
+ ,
+ ...PACKAGES.map((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:
+
+
+
{PACKAGES.map((pkg) => (