import { base } from "$app/paths"; import { ENABLE_ASSISTANTS } from "$env/static/private"; import { collections } from "$lib/server/database.js"; import type { Assistant } from "$lib/types/Assistant"; import { redirect } from "@sveltejs/kit"; import type { Filter } from "mongodb"; const NUM_PER_PAGE = 24; export const load = async ({ url }) => { if (!ENABLE_ASSISTANTS) { throw redirect(302, `${base}/`); } const modelId = url.searchParams.get("modelId"); const pageIndex = parseInt(url.searchParams.get("p") ?? "0"); // fetch the top assistants sorted by user count from biggest to smallest, filter out all assistants with only 1 users. filter by model too if modelId is provided const filter: Filter = { userCount: { $gt: 1 }, modelId: modelId ?? { $exists: true }, featured: true, }; const assistants = await collections.assistants .find(filter) .skip(NUM_PER_PAGE * pageIndex) .sort({ userCount: -1 }) .limit(NUM_PER_PAGE) .toArray(); const numTotalItems = await collections.assistants.countDocuments(filter); return { assistants: JSON.parse(JSON.stringify(assistants)) as Array, numTotalItems, numItemsPerPage: NUM_PER_PAGE, }; };