import { fetchScenes } from '#/src/scenes.js'; import { fetchActors } from '#/src/actors.js'; import { fetchMovies } from '#/src/movies.js'; import { curateScenesQuery } from '#/src/web/scenes.js'; import { curateActorsQuery } from '#/src/web/actors.js'; import { curateMoviesQuery } from '#/src/web/movies.js'; export async function onBeforeRender(pageContext) { const [searchScenes, searchActors, searchMovies] = await Promise.all([ fetchScenes(await curateScenesQuery({ ...pageContext.urlQuery, query: pageContext.urlParsed.search.q, scope: pageContext.urlParsed.search.scope || 'results', tagFilter: pageContext.tagFilter, }), { page: Number(pageContext.routeParams.page) || 1, limit: Number(pageContext.urlParsed.search.limit) || 15, }, pageContext.user), fetchActors(curateActorsQuery(pageContext.urlQuery), { page: Number(pageContext.routeParams.page) || 1, limit: Number(pageContext.urlParsed.search.limit) || 10, order: ['results', 'desc'], }, pageContext.user), fetchMovies(await curateMoviesQuery({ ...pageContext.urlQuery, scope: pageContext.routeParams.scope || 'results', }), { page: Number(pageContext.routeParams.page) || 1, limit: Number(pageContext.urlParsed.search.limit) || 5, }, pageContext.user), ]); const { scenes, aggYears, aggActors, aggTags, aggChannels, total: sceneTotal, } = searchScenes; const { actors, total: actorTotal, } = searchActors; const { movies, total: movieTotal, } = searchMovies; return { pageContext: { title: `Search '${pageContext.urlParsed.search.q || ''}'`, pageProps: { actors, scenes, movies, aggYears, aggActors, aggTags, aggChannels, sceneTotal, actorTotal, movieTotal, }, }, }; }