mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-03-21 18:04:39 -05:00
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import cachified from "@epic-web/cachified";
|
|
import type { LoaderFunctionArgs } from "react-router";
|
|
import { cache, IN_MILLISECONDS, ttl } from "~/utils/cache.server";
|
|
import * as ArtRepository from "../ArtRepository.server";
|
|
import { FILTERED_TAG_KEY_SEARCH_PARAM_KEY } from "../art-constants";
|
|
|
|
export const loader = async ({ request }: LoaderFunctionArgs) => {
|
|
const cachedArts = await cachified({
|
|
key: "arts",
|
|
cache,
|
|
ttl: ttl(IN_MILLISECONDS.TWO_HOURS),
|
|
async getFreshValue() {
|
|
return {
|
|
showcaseArts: await ArtRepository.findShowcaseArts(),
|
|
recentlyUploadedArts: await ArtRepository.findRecentlyUploadedArts(),
|
|
allTags: await ArtRepository.findAllTags(),
|
|
};
|
|
},
|
|
});
|
|
|
|
const filteredTagName = new URL(request.url).searchParams.get(
|
|
FILTERED_TAG_KEY_SEARCH_PARAM_KEY,
|
|
);
|
|
|
|
const filteredTag = filteredTagName
|
|
? cachedArts.allTags.find((t) => t.name === filteredTagName)
|
|
: null;
|
|
|
|
if (!filteredTag) {
|
|
return filteredTagName
|
|
? { ...cachedArts, showcaseArts: [] }
|
|
: cachedArts;
|
|
}
|
|
|
|
return {
|
|
...cachedArts,
|
|
showcaseArts: await ArtRepository.findShowcaseArtsByTag(filteredTag.id),
|
|
};
|
|
};
|