mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-16 03:23:29 +01:00
refactor: correctly generate routes
This commit is contained in:
@@ -30,7 +30,7 @@ import shikiLangJavascript from 'shiki/languages/javascript.tmLanguage.json';
|
|||||||
import shikiLangTypescript from 'shiki/languages/typescript.tmLanguage.json';
|
import shikiLangTypescript from 'shiki/languages/typescript.tmLanguage.json';
|
||||||
import shikiThemeDarkPlus from 'shiki/themes/dark-plus.json';
|
import shikiThemeDarkPlus from 'shiki/themes/dark-plus.json';
|
||||||
import shikiThemeLightPlus from 'shiki/themes/light-plus.json';
|
import shikiThemeLightPlus from 'shiki/themes/light-plus.json';
|
||||||
import vercelLogo from '../../../assets/powered-by-vercel.svg';
|
import vercelLogo from '../../../../../assets/powered-by-vercel.svg';
|
||||||
import { MDXRemote } from '~/components/MDXRemote';
|
import { MDXRemote } from '~/components/MDXRemote';
|
||||||
import { Nav } from '~/components/Nav';
|
import { Nav } from '~/components/Nav';
|
||||||
import { Class } from '~/components/model/Class';
|
import { Class } from '~/components/model/Class';
|
||||||
@@ -44,84 +44,92 @@ import { DESCRIPTION, PACKAGES } from '~/util/constants';
|
|||||||
import { findMember, findMemberByKey } from '~/util/model.server';
|
import { findMember, findMemberByKey } from '~/util/model.server';
|
||||||
import { tryResolveDescription } from '~/util/summary';
|
import { tryResolveDescription } from '~/util/summary';
|
||||||
|
|
||||||
export async function generateStaticParams() {
|
export async function generateStaticParams({ params }: { params: { package: string } }) {
|
||||||
return (
|
const packageName = params.package;
|
||||||
await Promise.all(
|
|
||||||
PACKAGES.map(async (packageName) => {
|
|
||||||
try {
|
|
||||||
let data: any[] = [];
|
|
||||||
let versions: string[] = [];
|
|
||||||
if (process.env.NEXT_PUBLIC_LOCAL_DEV) {
|
|
||||||
const res = await readFile(
|
|
||||||
join(cwd(), '..', '..', 'packages', packageName, 'docs', 'docs.api.json'),
|
|
||||||
'utf8',
|
|
||||||
);
|
|
||||||
data = JSON.parse(res);
|
|
||||||
} else {
|
|
||||||
const response = await fetch(`https://docs.discordjs.dev/api/info?package=${packageName}`);
|
|
||||||
versions = await response.json();
|
|
||||||
versions = versions.slice(-2);
|
|
||||||
|
|
||||||
for (const version of versions) {
|
try {
|
||||||
const res = await fetch(`https://docs.discordjs.dev/docs/${packageName}/${version}.api.json`);
|
let data: any[] = [];
|
||||||
data = [...data, await res.json()];
|
let versions: string[] = [];
|
||||||
|
if (process.env.NEXT_PUBLIC_LOCAL_DEV) {
|
||||||
|
const res = await readFile(join(cwd(), '..', '..', 'packages', packageName, 'docs', 'docs.api.json'), 'utf8');
|
||||||
|
data = JSON.parse(res);
|
||||||
|
} else {
|
||||||
|
const response = await fetch(`https://docs.discordjs.dev/api/info?package=${packageName}`);
|
||||||
|
versions = await response.json();
|
||||||
|
versions = versions.slice(-2);
|
||||||
|
|
||||||
|
for (const version of versions) {
|
||||||
|
const res = await fetch(`https://docs.discordjs.dev/docs/${packageName}/${version}.api.json`);
|
||||||
|
data = [...data, await res.json()];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Array.isArray(data)) {
|
||||||
|
const models = data.map((innerData) => createApiModel(innerData));
|
||||||
|
const pkgs = models.map((model) => findPackage(model, packageName)) as ApiPackage[];
|
||||||
|
|
||||||
|
return [
|
||||||
|
...versions.map((version) => ({ slug: ['packages', packageName, version] })),
|
||||||
|
...pkgs.flatMap((pkg, idx) =>
|
||||||
|
getMembers(pkg, versions[idx] ?? 'main').map((member) => {
|
||||||
|
if (member.kind === ApiItemKind.Function && member.overloadIndex && member.overloadIndex > 1) {
|
||||||
|
return {
|
||||||
|
slug: [
|
||||||
|
'packages',
|
||||||
|
packageName,
|
||||||
|
versions[idx] ?? 'main',
|
||||||
|
`${member.name}:${member.overloadIndex}:${member.kind}`,
|
||||||
|
],
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (Array.isArray(data)) {
|
return {
|
||||||
const models = data.map((innerData) => createApiModel(innerData));
|
slug: ['packages', packageName, versions[idx] ?? 'main', `${member.name}:${member.kind}`],
|
||||||
const pkgs = models.map((model) => findPackage(model, packageName)) as ApiPackage[];
|
};
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
return [
|
const model = createApiModel(data);
|
||||||
...versions.map((version) => ({ slug: ['packages', packageName, version] })),
|
const pkg = findPackage(model, packageName)!;
|
||||||
...pkgs.flatMap((pkg, idx) =>
|
|
||||||
getMembers(pkg, versions[idx] ?? 'main').map((member) => {
|
|
||||||
if (member.kind === ApiItemKind.Function && member.overloadIndex && member.overloadIndex > 1) {
|
|
||||||
return {
|
|
||||||
slug: [
|
|
||||||
'packages',
|
|
||||||
packageName,
|
|
||||||
versions[idx] ?? 'main',
|
|
||||||
`${member.name}:${member.overloadIndex}:${member.kind}`,
|
|
||||||
],
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return [
|
||||||
slug: ['packages', packageName, versions[idx] ?? 'main', `${member.name}:${member.kind}`],
|
{ slug: ['packages', packageName, 'main'] },
|
||||||
};
|
...getMembers(pkg, 'main').map((member) => {
|
||||||
}),
|
if (member.kind === ApiItemKind.Function && member.overloadIndex && member.overloadIndex > 1) {
|
||||||
),
|
return {
|
||||||
];
|
slug: ['packages', packageName, 'main', `${member.name}:${member.overloadIndex}:${member.kind}`],
|
||||||
}
|
};
|
||||||
|
|
||||||
const model = createApiModel(data);
|
|
||||||
const pkg = findPackage(model, packageName)!;
|
|
||||||
|
|
||||||
return [
|
|
||||||
{ slug: ['packages', packageName, 'main'] },
|
|
||||||
...getMembers(pkg, 'main').map((member) => {
|
|
||||||
if (member.kind === ApiItemKind.Function && member.overloadIndex && member.overloadIndex > 1) {
|
|
||||||
return {
|
|
||||||
slug: ['packages', packageName, 'main', `${member.name}:${member.overloadIndex}:${member.kind}`],
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
return { slug: ['packages', packageName, 'main', `${member.name}:${member.kind}`] };
|
|
||||||
}),
|
|
||||||
];
|
|
||||||
} catch {
|
|
||||||
return { slug: ['packages', '404'] };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return { slug: ['packages', packageName, 'main', `${member.name}:${member.kind}`] };
|
||||||
}),
|
}),
|
||||||
)
|
];
|
||||||
).flat();
|
} catch {
|
||||||
|
return { slug: [] };
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getData(slug: string[]) {
|
async function getData(packageName: string, slug: string[]) {
|
||||||
const [path, packageName = 'builders', branchName = 'main', member] = slug;
|
const [branchName = 'main', member] = slug;
|
||||||
|
|
||||||
if (path !== 'packages' || !PACKAGES.includes(packageName)) {
|
if (!PACKAGES.includes(packageName)) {
|
||||||
|
notFound();
|
||||||
|
}
|
||||||
|
|
||||||
|
let data;
|
||||||
|
try {
|
||||||
|
if (process.env.NEXT_PUBLIC_LOCAL_DEV) {
|
||||||
|
const res = await readFile(join(cwd(), '..', '..', 'packages', packageName, 'docs', 'docs.api.json'), 'utf8');
|
||||||
|
data = JSON.parse(res);
|
||||||
|
} else {
|
||||||
|
const res = await fetch(`https://docs.discordjs.dev/docs/${packageName}/${branchName}.api.json`, {
|
||||||
|
next: { revalidate: 3_600 },
|
||||||
|
});
|
||||||
|
data = await res.json();
|
||||||
|
}
|
||||||
|
} catch {
|
||||||
notFound();
|
notFound();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -161,21 +169,6 @@ async function getData(slug: string[]) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
let data;
|
|
||||||
try {
|
|
||||||
if (process.env.NEXT_PUBLIC_LOCAL_DEV) {
|
|
||||||
const res = await readFile(join(cwd(), '..', '..', 'packages', packageName, 'docs', 'docs.api.json'), 'utf8');
|
|
||||||
data = JSON.parse(res);
|
|
||||||
} else {
|
|
||||||
const res = await fetch(`https://docs.discordjs.dev/docs/${packageName}/${branchName}.api.json`, {
|
|
||||||
next: { revalidate: 3_600 },
|
|
||||||
});
|
|
||||||
data = await res.json();
|
|
||||||
}
|
|
||||||
} catch {
|
|
||||||
notFound();
|
|
||||||
}
|
|
||||||
|
|
||||||
const model = createApiModel(data);
|
const model = createApiModel(data);
|
||||||
const pkg = findPackage(model, packageName);
|
const pkg = findPackage(model, packageName);
|
||||||
|
|
||||||
@@ -261,8 +254,8 @@ function member(props?: ApiItemJSON | undefined) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default async function Page({ params }: { params: { slug: string[] } }) {
|
export default async function Page({ params }: { params: { package: string; slug: string[] } }) {
|
||||||
const data = await getData(params.slug);
|
const data = await getData(params.package, params.slug);
|
||||||
|
|
||||||
// const name = useMemo(
|
// const name = useMemo(
|
||||||
// () => `discord.js${params.data?.member?.name ? ` | ${params.data.member.name}` : ''}`,
|
// () => `discord.js${params.data?.member?.name ? ` | ${params.data.member.name}` : ''}`,
|
||||||
10
apps/website/src/app/docs/packages/[package]/layout.tsx
Normal file
10
apps/website/src/app/docs/packages/[package]/layout.tsx
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
import type { PropsWithChildren } from 'react';
|
||||||
|
import { PACKAGES } from '~/util/constants';
|
||||||
|
|
||||||
|
export async function generateStaticParams() {
|
||||||
|
return PACKAGES.map((packageName) => ({ package: packageName }));
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function PackageLayout({ children }: PropsWithChildren) {
|
||||||
|
return children;
|
||||||
|
}
|
||||||
@@ -5,10 +5,6 @@ import Link from 'next/link';
|
|||||||
import { notFound } from 'next/navigation';
|
import { notFound } from 'next/navigation';
|
||||||
import { PACKAGES } from '~/util/constants';
|
import { PACKAGES } from '~/util/constants';
|
||||||
|
|
||||||
export async function generateStaticParams() {
|
|
||||||
return PACKAGES.map((packageName) => ({ package: packageName }));
|
|
||||||
}
|
|
||||||
|
|
||||||
async function getData(pkg: string) {
|
async function getData(pkg: string) {
|
||||||
if (!PACKAGES.includes(pkg)) {
|
if (!PACKAGES.includes(pkg)) {
|
||||||
notFound();
|
notFound();
|
||||||
|
|||||||
Reference in New Issue
Block a user